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

算法學社
記錄難忘的征途
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>
            亚洲娇小video精品| 欧美日韩福利| 亚洲国产成人精品视频| 久久蜜桃资源一区二区老牛| 99在线观看免费视频精品观看| 亚洲一区二区在线播放| 99国产精品视频免费观看一公开 | 亚洲精品一区二区三区四区高清 | 麻豆精品网站| 在线成人激情黄色| 久久激情网站| 欧美亚洲免费高清在线观看| 国产精品乱人伦中文| 亚洲视频在线观看三级| 最近看过的日韩成人| 欧美日韩国产成人| 在线午夜精品| 欧美中文在线观看| 欧美成人四级电影| 国产精品视频一二| 亚洲国产第一| 欧美亚洲免费| 欧美不卡福利| 一区二区av在线| 久久视频这里只有精品| 欧美日韩综合一区| 国产亚洲观看| 一区二区三区日韩精品视频| 久久久久久穴| 一区二区av在线| 免费在线国产精品| 国内精品国产成人| 亚洲欧美中文日韩在线| 亚洲电影免费观看高清完整版在线| 99国产精品久久久久久久成人热 | 欧美三区在线观看| 亚洲黄色影院| 欧美中文字幕| 中日韩高清电影网| 美女性感视频久久久| 国产视频久久久久久久| 亚洲制服少妇| 99香蕉国产精品偷在线观看| 久久男女视频| 韩国久久久久| 久久三级福利| 久久国产精品久久久久久久久久| 国产精品免费aⅴ片在线观看| 99精品欧美| 亚洲精品国产精品乱码不99按摩| 美国十次了思思久久精品导航| 国产日韩欧美91| 午夜精品久久久久久久白皮肤 | 欧美一区二区在线免费播放| 亚洲国产欧美一区| 亚洲国产日韩欧美一区二区三区| 欧美一级二级三级蜜桃| 99re热精品| 欧美成人一品| 欧美少妇一区| 欧美成人久久| 国产片一区二区| 亚洲精品国产精品乱码不99按摩| 国内精品免费在线观看| 日韩视频一区二区三区| 狠狠色狠狠色综合人人| 一本色道久久综合亚洲精品婷婷| 影音先锋亚洲视频| 亚洲女人小视频在线观看| 亚洲精品视频二区| 久久久久国色av免费看影院| 欧美日韩国产天堂| 最新国产成人av网站网址麻豆| 欧美高清日韩| 欧美日韩国产免费观看| 这里只有精品丝袜| 亚洲欧美bt| 伊人男人综合视频网| 亚洲国产婷婷香蕉久久久久久99 | 狠狠久久婷婷| 欧美激情在线狂野欧美精品| 欧美久久久久中文字幕| 亚洲一区视频| 久久精品女人| 一区二区三区欧美日韩| 亚洲欧美欧美一区二区三区| 激情成人在线视频| 亚洲日本中文字幕| 国产视频久久网| 欧美激情1区| 国产精品一级二级三级| 你懂的视频欧美| 欧美性猛交视频| 久久―日本道色综合久久| 欧美xxx在线观看| 欧美亚洲一级| 欧美成人日本| 久久久久久久久久码影片| 欧美激情视频给我| 久久久水蜜桃av免费网站| 欧美金8天国| 久久久久欧美| 欧美色大人视频| 欧美高清在线视频| 国产精品一区视频网站| 亚洲国产天堂久久综合网| 国产在线视频欧美| 一区二区冒白浆视频| 亚洲国产激情| 欧美一区二区三区男人的天堂 | 欧美日韩国产限制| 亚洲欧美国产三级| 国模私拍一区二区三区| 亚洲精品乱码久久久久久日本蜜臀 | 一区二区在线观看av| 久久久久久久综合狠狠综合| 久久一区二区三区四区五区| 激情久久五月| 男男成人高潮片免费网站| 亚洲免费黄色| 欧美色图麻豆| 美女啪啪无遮挡免费久久网站| 国产精品久久久久久久久免费桃花 | 亚洲国产精品成人久久综合一区 | 一区二区亚洲欧洲国产日韩| 亚洲欧美日韩国产另类专区| 一区二区三区国产在线| 欧美va亚洲va香蕉在线| 乱人伦精品视频在线观看| 国产日韩一区二区| 亚洲一区二区三区在线看| 中文国产成人精品久久一| 欧美乱大交xxxxx| 亚洲激情第一区| 亚洲精品在线免费观看视频| 久久综合九色综合网站| 欧美mv日韩mv国产网站app| 精品动漫一区二区| 久热成人在线视频| 欧美高清在线视频| 亚洲精品女人| 欧美日韩精品一区二区三区四区| 亚洲日本欧美| 午夜视频一区在线观看| 国产日韩精品一区二区三区在线| 欧美一区二区三区在线看| 久久久久久夜精品精品免费| 国内久久视频| 久久亚洲精品一区二区| 欧美激情一区二区| 99re6热在线精品视频播放速度 | 在线成人免费视频| 久久综合伊人77777| 亚洲成人在线视频播放| 99国产精品国产精品久久| 欧美精品免费视频| 99精品99久久久久久宅男| 亚洲欧美成人| 国产一区二区精品久久91| 久久一二三国产| 亚洲国产精品电影| 亚洲欧美日韩另类| 极品少妇一区二区三区精品视频| 免费日韩成人| 亚洲天堂成人在线视频| 日韩午夜在线视频| 亚洲国产三级网| 久久亚洲私人国产精品va媚药 | 免费在线播放第一区高清av| 欧美一区二区三区四区视频| 亚洲午夜羞羞片| 亚洲五月婷婷| 亚洲一区视频| 午夜视频一区| 欧美诱惑福利视频| 欧美一区二区性| 久久精品国产91精品亚洲| 午夜宅男久久久| 欧美一区二区日韩一区二区| 性色av一区二区三区红粉影视| 亚洲欧美中日韩| 久久精品视频免费播放| 久久精品最新地址| 欧美激情小视频| 久久成人免费电影| 中日韩在线视频| 亚洲国产1区| 美女脱光内衣内裤视频久久网站| 亚洲尤物视频在线| 亚洲精品在线三区| 黄网动漫久久久| 国产精品老牛| 欧美日韩第一区日日骚| 老巨人导航500精品| 性久久久久久久久| 亚洲香蕉网站| 国产精品99久久久久久宅男| 亚洲人妖在线| 亚洲缚视频在线观看| 欧美成人久久|