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

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

300pt

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

思路分析

    因為RP總是很差,所以拿到被隱藏的數的時候是從最小開始拿的。如果每次都拿被隱藏的數的話,肯定是從小到大的一圈一圈的拿。
    如果拿沒被隱藏的數的話,那么直接拿最大的就好了。
    于是算法和去年上海regional第一題就一樣一樣了.... 前面要么一圈一圈拿被隱藏的數,要么都拿最大的數。
    這個是貪心的。
    最后P會剩一個余數。
    暴力判斷是拿最大的還是拿被隱藏的(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]。現在有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>
            久久国产主播精品| 亚洲国产毛片完整版| 亚洲区国产区| 亚洲精品久久久蜜桃| 欧美日韩综合视频| 久久精品72免费观看| 六月婷婷久久| 亚洲专区免费| 米奇777在线欧美播放| 亚洲手机在线| 久久久久在线| 午夜综合激情| 欧美精品国产一区二区| 欧美一区二区三区啪啪| 欧美成人亚洲| 久久久另类综合| 国产精品久久久久av| 欧美黑人国产人伦爽爽爽| 国产精品视频久久一区| 91久久精品国产91久久性色tv| 国产噜噜噜噜噜久久久久久久久| 欧美激情中文不卡| 国内欧美视频一区二区| 亚洲系列中文字幕| 一区二区不卡在线视频 午夜欧美不卡在| 亚洲视频一二区| 亚洲麻豆视频| 久久久蜜桃精品| 久久精品久久99精品久久| 国产精品久久久久久模特| 亚洲成人在线免费| 欧美一区免费视频| 午夜精品久久久久久久99热浪潮| 欧美高清日韩| 久热国产精品视频| 国产日韩高清一区二区三区在线| 一区二区日韩伦理片| 亚洲精品乱码久久久久久蜜桃麻豆 | 免费日韩视频| 久久永久免费| 国产欧美日韩精品专区| 亚洲天堂激情| 亚洲女人天堂成人av在线| 欧美日韩的一区二区| 亚洲激情网站| 一区二区三区**美女毛片| 欧美成人综合一区| 欧美国产免费| 亚洲高清不卡一区| 久久影音先锋| 亚洲电影av| 亚洲精品四区| 欧美人与禽猛交乱配视频| 亚洲人体偷拍| 亚洲网在线观看| 国产精品theporn| 亚洲一区二区毛片| 欧美与黑人午夜性猛交久久久| 国产精品一区毛片| 欧美一区二区三区视频在线观看| 久久精品二区| 伊人成人在线| 欧美mv日韩mv国产网站| 亚洲区免费影片| 一区二区三区欧美在线| 国产精品成人一区二区三区吃奶| 亚洲午夜免费福利视频| 久久久久久69| 亚洲黄色一区二区三区| 欧美日韩国语| 午夜精品一区二区三区在线播放| 久久成人免费| 伊人久久大香线蕉av超碰演员| 久久伊人精品天天| 亚洲激情视频在线| 欧美一级电影久久| 国产综合久久久久久| 欧美本精品男人aⅴ天堂| 一本色道精品久久一区二区三区| 欧美伊人精品成人久久综合97| 国外成人在线视频| 欧美激情亚洲精品| 欧美一区免费视频| 亚洲欧洲精品天堂一级| 欧美一区二区日韩| 91久久在线| 国产精品视频你懂的| 另类综合日韩欧美亚洲| 亚洲神马久久| 欧美超级免费视 在线| 亚洲午夜羞羞片| 激情欧美一区二区| 欧美午夜激情视频| 老鸭窝毛片一区二区三区| 夜夜嗨av一区二区三区四区| 美女成人午夜| 午夜精品久久久久久久99樱桃 | 亚洲区一区二区三区| 久久久久高清| 在线亚洲自拍| 亚洲国产精品精华液2区45| 国产精品国产一区二区| 欧美成人午夜激情在线| 欧美怡红院视频| 亚洲乱码久久| 欧美激情一区二区三区蜜桃视频| 午夜精品影院| 99成人在线| 亚洲第一精品久久忘忧草社区| 国产精品国产精品| 欧美精品久久天天躁| 久久精品免费观看| 亚洲一区二区视频在线| 日韩网站在线观看| 欧美激情一区二区三区四区 | 国产精品久久久久久久午夜片| 久久综合免费视频影院| 午夜国产欧美理论在线播放| 亚洲人成人77777线观看| 久久综合伊人| 久久精品成人| 亚洲欧美在线免费| 中文亚洲字幕| 日韩一二三在线视频播| 亚洲国内精品| 在线观看欧美日韩国产| 黄色一区二区在线观看| 国产日韩精品久久久| 国产欧美日韩在线观看| 国产精品一区二区男女羞羞无遮挡| 欧美日韩综合视频网址| 欧美视频第二页| 欧美日韩亚洲一区二区| 欧美伦理影院| 欧美日韩一二三区| 欧美日韩午夜在线视频| 欧美三级电影一区| 欧美日韩亚洲在线| 国产精品国产亚洲精品看不卡15| 欧美婷婷在线| 国产精品欧美日韩| 国产一区二区三区免费不卡 | 中文av字幕一区| 99国产精品99久久久久久粉嫩| 亚洲精品国产精品久久清纯直播| 亚洲国产导航| 亚洲精品一二区| 亚洲视频中文字幕| 新67194成人永久网站| 久久精品国产在热久久 | 亚洲一区美女视频在线观看免费| 亚洲色在线视频| 性欧美xxxx视频在线观看| 久久精品人人爽| 久久综合久久综合久久综合| 久久香蕉国产线看观看网| 欧美va日韩va| 亚洲精品欧美一区二区三区| 日韩香蕉视频| 欧美亚洲日本网站| 久久一日本道色综合久久| 欧美精品三级在线观看| 国产精品第一页第二页第三页| 国产精品视频午夜| 激情久久一区| 99精品免费| 欧美一区二区三区视频| 毛片精品免费在线观看| 最新成人在线| 亚洲欧美中文在线视频| 麻豆av福利av久久av| 欧美视频网址| 黄色日韩网站| 亚洲视频图片小说| 久久久噜噜噜久久| 日韩午夜黄色| 久久精品中文字幕一区二区三区| 欧美激情成人在线| 国产亚洲欧美日韩一区二区| 亚洲日本欧美在线| 欧美一区二区三区电影在线观看| 久久综合久久综合这里只有精品| 亚洲欧洲日本专区| 久久精品99| 国产精品麻豆va在线播放| 在线精品视频在线观看高清| 亚洲深夜影院| 另类av一区二区| 这里只有精品在线播放| 巨乳诱惑日韩免费av| 国产精品久久国产愉拍| 亚洲精品一二区| 久久久久九九九| 亚洲午夜精品视频| 欧美另类视频| 亚洲国产精品高清久久久| 欧美在线一区二区| 夜夜嗨av一区二区三区四区| 牛夜精品久久久久久久99黑人 | 999亚洲国产精|