青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

算法學社
記錄難忘的征途
posts - 141,comments - 220,trackbacks - 0
漲了111 rating 真是耗rp啊.....

300pt

    有一個1到N(N<50)的排列,序列中的一些數(shù)被隱藏了(表示為0)。你每一次都可以選擇數(shù)列中某個位置的一個數(shù)作為自己的得分,不論這個數(shù)是否被隱藏,你都會得到相應的分數(shù)。
    請問最少取多少個數(shù)能保證人品最壞的情況下至少拿到P(P<1,000,000)分。

思路分析

    因為RP總是很差,所以拿到被隱藏的數(shù)的時候是從最小開始拿的。如果每次都拿被隱藏的數(shù)的話,肯定是從小到大的一圈一圈的拿。
    如果拿沒被隱藏的數(shù)的話,那么直接拿最大的就好了。
    于是算法和去年上海regional第一題就一樣一樣了.... 前面要么一圈一圈拿被隱藏的數(shù),要么都拿最大的數(shù)。
    這個是貪心的。
    最后P會剩一個余數(shù)。
    暴力判斷是拿最大的還是拿被隱藏的(2選1,交叉著來是不可能的...)。
 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstdlib>
 4 #include<vector>
 5 #include<cstring>
 6 using namespace std;
 7 #define re(i,n) for(int i=0;i<n;i++)
 8 #define re1(i,n) for(int i=1;i<=n;i++)
 9 #define re2(i,n) for(int i=0;i<=n;i++)
10 #define re3(i,n) for(int i=1;i<n;i++)
11 #define clr(a,n) memset(a,n,sizeof(a))
12 template <typename T> inline T chkmin(T& a,T b){ return a > b ? a = b : a ; }
13 template <typename T> inline T chkmax(T& a,T b){ return a < b ? a = b : a ; }
14 int hash[100];
15 int cal(int P,int mx){
16     if(!mx) return ~0u>>2;
17     return P/mx + (P%mx >0);
18 }
19 int cal(int P,vector<int> num){
20     sort(num.begin(),num.end());
21     int sum =0;
22     re(i,num.size()) {
23         sum+=num[i];
24         if(sum >= P) return i+1;
25     }
26     return ~0u>>2;
27 }
28 class BlurredDartboard{
29     public :
30     int minThrows(vector <int> num, int P){
31         int n = num.size(),mx = 0;
32         re(i,n){
33             hash[num[i]] = 1;
34             chkmax(mx,num[i]);
35         }
36         vector <int> temp;
37         re1(i,n) if(!hash[i]) temp.push_back(i);
38         int m = temp.size(),suma = 0;
39         re(i,m) suma += temp[i];
40         if(!m) m = 1;
41         int sumb =  mx*m;
42         int sum= max(suma,sumb);
43         int ans = P/sum*m;
44         cout<<ans<<endl;
45         P %=sum;
46         if(P==0) return ans;
47         int a = cal(P,mx);
48         int b = cal(P,temp);
49         return ans + min(a,b);
50     }
51 };
52 

550pt

    有N(N<50)本書,每本書都有一個價值w[i]。現(xiàn)在有M次操作,每次操作i(i=0 mod 2),小A可以從自己的書包拿出書向小B的書包里放最多move[i]本書。
    每次操作j(j=0 mod 1),小B可以從自己書包往小A書包里放最多move[j]本書。
    第一次操作,小A要從書堆中拿出move[0]本書裝到B的書包中。
    最后,小A的書包中書的總價值為Wa,小B為Wb。小A想讓Wb-Wa最大, 小B相讓Wa-Wb最大.
    假設二個人都足夠聰明.... 輸出最后的Wa和Wb。
    如果有多種選擇,那么輸出Wa+Wb最大的那種可能。

思路分析

    沒敲完... 殘念啊... 我果然還是弱阿....
    顯然除了第一步從書堆里放書意外,一旦書包中的書確定了,兩人都是貪心的拿書。
    問題就是從書堆中拿哪些書...... DP就可以了吧....(ms有更簡單的??)
    update: 下午閑著沒事,就敲完了,可以去吃飯了(ms當時就是寫完了也進不了前50.... 還是弱 阿....)
 1 #include<iostream>
 2 #include<cstdio>
 3 #include<algorithm>
 4 #include<cstring>
 5 #include<vector>
 6 using namespace std;
 7 int hash[100];
 8 void work(vector<int> B,vector<int> num){
 9     vector<int> A;
10     for(int i=1; i< num.size();i++){
11         if(i&1){
12             sort(B.begin(),B.end());
13             int n = B.size();
14             int m = min(n,num[i]);
15             for(int j = n-1; j>= n-m; j--){
16                 A.push_back(B[j]);
17                 B.erase((vector<int>::iterator)&B[j]);
18             }
19         }
20         else {
21             sort(A.begin(),A.end());
22             int n = A.size();
23             int m = min(n,num[i]);
24             for(int j = n-1; j>= n-m; j--){
25                 B.push_back(A[j]);
26                 A.erase((vector<int>::iterator)&A[j]);
27             }
28         }
29     }
30     for(int i=0;i<A.size();i++) hash[A[i]] = -1;
31     for(int i=0;i<B.size();i++) hash[B[i]] = 1;
32 }
33 const int inf = ~0u>>2;
34 int dp[100][100],P[100][100];
35 class HeavyBooks{
36     public : vector <int> findWeight(vector<int> book,vector <int> mv){
37         vector<int> temp;
38         sort(book.begin(),book.end());
39         int n =book.size();
40         int m = min(mv[0],n);
41         for(int i =0; i<m;i++) temp.push_back(i);
42         work(temp,mv);
43     //    for(int i=0;i<m;i++) cout<<hash[i]<<" "; cout<<endl;
44         for(int j=0;j<m;j++)
45             for(int i=j;i<n;i++)
46                 if(i == j){
47                     P[i][j] = i-1;
48                     dp[i][j] =(i ? dp[i-1][j-1]:0) + hash[j] * book[i];
49                 }
50                 else if(j == 0){
51                     dp[i][0] = hash[0] * book[i];
52                     P[i][0] = -1;
53                 }
54                 else {
55                     int mx = -inf,s;
56                     for(int k = i-1; k>=j-1;k--)
57                         if(dp[k][j-1] > mx){
58                             s = k; mx = dp[k][j-1];
59                         }
60                     dp[i][j] = hash[j] * book[i] + mx;
61                     P[i][j] = s;
62                 }
63         int mx = -inf,s;
64         for(int i=n-1; i>=m-1;i--)
65             if(dp[i][m-1]>mx){
66                 s = i;
67                 mx = dp[i][m-1];
68             }
69         int A = 0, B = 0;
70         for(int i=m-1;i>=0;i--){
71             //cout<<s<<endl;
72             if(hash[i]>0) B += book[s]; else A += book[s];
73             s = P[s][i];
74         }
75         temp.clear();
76         temp.push_back(A);
77         temp.push_back(B);
78         return temp;
79     }
80 };
81 
posted on 2012-05-13 08:47 西月弦 閱讀(416) 評論(0)  編輯 收藏 引用 所屬分類: 比賽感言
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久亚洲国产精品一区二区| 国产一区二区三区直播精品电影 | 亚洲香蕉成视频在线观看| 亚洲电影免费在线| 欧美岛国在线观看| 久久久在线视频| 久久午夜电影网| 亚洲大胆人体在线| 亚洲精品一区二区三区婷婷月| 日韩视频在线一区| 欧美一区二视频| 欧美国产一区二区三区激情无套| 欧美三日本三级少妇三2023 | 麻豆亚洲精品| 亚洲电影欧美电影有声小说| 99国产精品视频免费观看一公开 | 亚洲网站视频| 久久aⅴ国产欧美74aaa| 欧美成人精品福利| 国产精品亚洲激情| 亚洲国产成人精品女人久久久| 一区二区三区久久久| 久久动漫亚洲| 99pao成人国产永久免费视频| 久久成人精品| 国产精品成人一区二区网站软件 | 国产视频一区二区三区在线观看| 狠色狠色综合久久| 亚洲资源av| 欧美激情精品久久久久久免费印度| av成人免费在线| 美腿丝袜亚洲色图| 国产综合欧美| 午夜精品偷拍| 日韩午夜av在线| 开心色5月久久精品| 国产欧美另类| 午夜天堂精品久久久久| 亚洲欧洲中文日韩久久av乱码| 欧美一区二区啪啪| 国产精品久久久久久久久免费桃花 | 国产精品日本| 99精品视频一区| 美女精品网站| 欧美一区二区女人| 国产欧美69| 亚洲欧美大片| aⅴ色国产欧美| 欧美精品九九99久久| 亚洲高清一二三区| 麻豆国产精品777777在线| 国产一区二区三区无遮挡| 亚洲欧美日韩国产综合精品二区| 亚洲精品免费电影| 欧美另类videos死尸| 亚洲精品综合| 亚洲黄网站在线观看| 欧美成人国产| 99视频一区| 99视频一区| 国产精品嫩草99av在线| 欧美一区二区成人| 欧美专区在线播放| 在线日韩中文字幕| 亚洲国产精品综合| 欧美日韩精品在线| 亚洲欧美视频在线| 新67194成人永久网站| 国内成+人亚洲+欧美+综合在线| 久久精品99久久香蕉国产色戒| 午夜天堂精品久久久久 | 午夜精品免费在线| 国产欧美一区二区精品性色| 亚洲综合欧美日韩| 黄色成人在线观看| 欧美成人综合在线| 女同性一区二区三区人了人一| 亚洲欧洲综合另类| 亚洲最新视频在线| 国产欧美一区二区三区另类精品| 亚洲欧洲av一区二区三区久久| 亚洲一区日韩在线| 国产午夜精品一区理论片飘花 | 亚洲国产一区二区a毛片| 欧美国产精品中文字幕| 欧美巨乳在线| 欧美亚洲综合在线| 久久综合给合久久狠狠色 | av72成人在线| 亚洲午夜羞羞片| 在线日韩电影| 一区二区三区四区五区精品| 国产一区深夜福利| 亚洲日本免费| 黑人操亚洲美女惩罚| 亚洲免费电影在线观看| 国产亚洲精品高潮| 日韩视频免费观看| 尤物网精品视频| 亚洲天堂偷拍| 亚洲日韩欧美视频一区| 午夜精品成人在线视频| 亚洲精品系列| 欧美一区二区久久久| 99精品视频免费| 久久精品日韩欧美| 午夜精品视频| 欧美久久久久| 欧美大色视频| 国内精品视频在线观看| 99国内精品| 亚洲一区二区三区激情| 亚洲黄色av| 久久岛国电影| 欧美一区二区在线观看| 欧美日韩视频在线| 亚洲国产一区二区三区a毛片| 国产欧美一级| 亚洲午夜精品视频| 亚洲图片在线| 欧美精品在线播放| 亚洲国产成人91精品| 极品尤物一区二区三区| 亚洲综合国产精品| 亚洲直播在线一区| 欧美日韩精品免费在线观看视频| 免播放器亚洲| 激情久久久久| 久久福利精品| 久久综合伊人77777蜜臀| 国产在线拍偷自揄拍精品| 亚洲欧美日韩国产精品| 欧美一级久久久| 国产日韩欧美亚洲| 亚洲女同性videos| 国产日韩欧美精品| 欧美一区二区高清| 国产精品伦一区| 亚洲五月六月| 先锋a资源在线看亚洲| 欧美三级视频在线观看| 99精品久久久| 亚洲一区二区三区成人在线视频精品| 欧美激情一区二区三区在线视频观看| 蜜臀av性久久久久蜜臀aⅴ| 影音先锋久久精品| 欧美bbbxxxxx| 日韩一区二区免费高清| 亚洲欧美日韩国产一区| 国产欧美一区二区三区在线看蜜臀| 亚洲在线一区二区| 久久蜜桃资源一区二区老牛| 极品少妇一区二区| 欧美粗暴jizz性欧美20| 亚洲日本欧美天堂| 这里只有精品视频| 国产乱人伦精品一区二区| 久久国产精品毛片| 欧美高清在线一区| 亚洲免费一区二区| 国产在线一区二区三区四区| 猫咪成人在线观看| 国产亚洲欧美另类一区二区三区| 午夜精品久久久久久久蜜桃app | 亚洲欧美激情视频| 欧美成人首页| 亚洲欧美日本精品| 亚洲国产成人精品女人久久久 | 国产精品激情偷乱一区二区∴| 亚洲女人av| 亚洲风情在线资源站| 亚洲中无吗在线| 伊人男人综合视频网| 欧美精品在线观看91| 性做久久久久久久久| 亚洲国产专区校园欧美| 欧美在线free| 99视频一区二区| 韩日欧美一区| 国产精品成av人在线视午夜片| 欧美在线视频全部完| 亚洲激情女人| 久久视频在线看| 亚洲免费视频一区二区| 亚洲国产精品久久精品怡红院 | 欧美大片免费观看在线观看网站推荐| 999在线观看精品免费不卡网站| 久久亚洲高清| 亚洲免费视频网站| 一本色道**综合亚洲精品蜜桃冫| 国产深夜精品福利| 久久久久国色av免费观看性色| 91久久久久久| 91久久精品国产| 国产精品久久久久久久久免费樱桃 | 国产亚洲欧美日韩一区二区| 欧美激情中文不卡| 久久久久一区| 性色av一区二区三区| a91a精品视频在线观看|