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

Omni Inspirations

problems & programs ~

統計

留言簿

Friends

閱讀排行榜

評論排行榜

【除草】Baltic OI 2010 day2 candies

很久沒寫了。。。

題意:
給你一個裝箱問題(N<=100 Ai<=7000)  記用這些有限物品能拼成的重量種數為Ans
求 把i物品Ai 換成X后 使新的能得到的重量種數Ret最大 同時使X最小 求X和Ret

做法:
這個題我做了一晚上加一上午!!

猜想:
換一個物品 等價于 先去掉這個物品做N-1個物品 最后加入一個物品并更新
(寫了個暴力  是符合的)
然后就將問題變為了真正的兩問:
第一問,求X使得除了X的N-1個物品能得到的種數Ans'最大
(因為最終方案一樣 所以得刪一個最沒用的)
第二問,添加一個物品 使得最后得到的最大

對于第一問   一個簡單的想法便是枚舉去掉哪個物品 做100次裝箱問題
但是我們還是遇到了瓶頸  做一次裝箱問題復雜度O(100^2*7000) 枚舉的話 做一次就得0.5秒 根本無法滿足
(很不幸我想不到不枚舉的方法 只能用區間背包這個不好估計復雜度的來完成 實際效果確實還得TLE)

【我的做法便是將100個物品分為10組 枚舉每10個物品 先將另外90個物品做好區間背包 保存這個答案數組
然后對于這10個物品 每次添加9個物品
算下復雜度
原本要放進99*100=9900次物品
現在 90*10+9*9*10=2000次左右 整整減少了5倍!

對于第二問   事實上我們可以發現  添加Y=(∑Ai)-X+1這個物品是肯定可以將方案數增加最多的 因為
假設用N-1個物品能得到的裝箱數組是
1 2 3 4 5 6 7 8 9 10 11 12
o x o o o x o o x o   x   x  ....
那么11必然是一個使方案最大可行解 亦可能是最優解
所以我們如果要找一個比Y更優的解 必然要滿足原本擁有的所有解加上Y'    原本都不可行!

這樣就把問題轉化為如下:
對于一個1..700000的布爾數組A 求一個最小的X
使得對于任意一個i A[i]=1 A[i+X]=0。
(很不幸除了枚舉X 這一問我也不會做 )

【我的做法
先預處理前綴和  即從1開始到i能拼成的個數
先把這個枚舉加些剪枝 將原來拼不成的重量進行枚舉
再從這些拼不成的重量里枚舉X   因為區間背包算出來的是許多個區間 最后枚舉這些區間
對于一個區間[a,b] 如果X是可行的那必然有 sum(a+X,b+X)=0】

事實上這么做居然就過了!因為區間數不太多 我能構造的最牛逼的數據 也只能 O(300000*5000) 這個還是勉強能跑過的
對于官方數據 每個點都能在0.2s內跑過!!

這樣終于AC了此題!!

(另外求標準的優美的算法!!!!!!!!!)

  1 #include <cstdio>
  2 #include <cstring>
  3 #include <algorithm>
  4 #define n 20005
  5 using namespace std;
  6 struct Tintv
  7 {
  8     int x,y;
  9 }    P[n],Q[n],R[n],Ptmp[n];
 10 int len,sum,lentmp,N,M,A[105],list[30];
 11 int H[n],v[n],d[n],HLength,S[1400005];
 12 bool F[1400005];
 13 inline int Calc(int Left,int Right,int u,int v)
 14 {
 15     R[0].x=R[0].y=-2;
 16     for (int l=Left;l<=Right;++l)
 17     if (l<u||l>v)
 18     {
 19         for (int i=1;i<=len;++i)
 20             Q[i].x=P[i].x+A[l],Q[i].y=P[i].y+A[l];
 21         int r=0;
 22         for (int p=1,q=1;p<=len||q<=len;)
 23         if (p<=len&&(q>len||P[p].x<Q[q].x))
 24         {
 25             if (R[r].y+1>=P[p].x)    R[r].y=max(R[r].y,P[p].y);
 26             else    R[++r].x=P[p].x,R[r].y=P[p].y;
 27             ++p;
 28         }
 29         else
 30         {
 31             if (R[r].y+1>=Q[q].x)    R[r].y=max(R[r].y,Q[q].y);
 32             else    R[++r].x=Q[q].x,R[r].y=Q[q].y;
 33             ++q;
 34         }
 35         for (int i=1;i<=r;++i)
 36             P[i]=R[i];
 37         len=r;
 38     }
 39     int tmp=-1;
 40     for (int i=1;i<=len;++i)
 41         tmp+=P[i].y-P[i].x+1;
 42     return tmp;
 43 }
 44 inline bool check(int u)
 45 {
 46     for (int i=1;i<=len;++i)
 47         if (S[P[i].y+u]-S[P[i].x+u-1]>0)    return 0;
 48     return 1;
 49 }
 50 int main()
 51 {
 52     scanf("%d",&N);
 53     for (int i=1;i<=N;++i)
 54         scanf("%d",&A[i]),M+=A[i];
 55     sort(A+1,A+N+1);
 56     int ret=0,Ret=0,tmp;
 57     list[++list[0]]=1;
 58     for (int i=1;i<=N;i+=10)
 59     {
 60         tmp=i+10;
 61         if (tmp>N)    tmp=N+1;
 62         list[++list[0]]=tmp;
 63     }
 64     for (int i=1;i<list[0];++i)
 65     {
 66         memset(P,0,sizeof(P)),len=1;
 67         sum=Calc(1,N,list[i],list[i+1]-1);
 68         memcpy(Ptmp,P,sizeof(P));
 69         lentmp=len;
 70         for (int j=list[i];j<list[i+1];++j)
 71         if (A[j]!=A[j-1])
 72         {
 73             len=lentmp;
 74             memcpy(P,Ptmp,sizeof(Ptmp));
 75             tmp=Calc(list[i],list[i+1]-1,j,j);
 76             if (tmp>Ret)    ret=j,Ret=tmp;
 77         }
 78     }
 79     printf("%d ",A[ret]);
 80     memset(P,0,sizeof(P)),len=1;
 81     Calc(1,N,ret,ret);
 82     for (int i=1;i<=len;++i)
 83     for (int j=P[i].x;j<=P[i].y;++j)
 84         S[j]=1;
 85     for (int i=1;i<=1400000;++i)
 86         S[i]+=S[i-1];
 87     ++len;
 88     P[len].x=P[len-1].y+2;
 89     P[len].y=1<<30;
 90     for (int i=1;i<len;++i)
 91     {
 92         bool mk=0;
 93         for (int j=P[i].y+1;j<P[i+1].x;++j)
 94         if (check(j))  
 95         {
 96             ret=j;mk=1;break;
 97         }
 98         if (mk)    break;
 99     }
100     printf("%d\n",ret);
101     return 0;
102 }
103 

posted on 2010-05-21 15:10 jsn1993 閱讀(1791) 評論(2)  編輯 收藏 引用 所屬分類: Mix

評論

# re: 【除草】Baltic OI 2010 day2 candies 2010-06-30 09:42 jiakai

b[1], b[2], ..., b[i]分別為2^i,后面的都取7000, 則所有偶數都可以組合出來,奇數都不可組合出來,區間數是O(n)級別的,沒有優化效果。。  回復  更多評論   

# re: 【除草】Baltic OI 2010 day2 candies 2010-06-30 09:57 jsn1993

@jiakai
對 這是個人品算法 所以求標準算法  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩一区二区在线观看视频| 亚洲特黄一级片| 亚洲一区二区三区高清| 亚洲剧情一区二区| 亚洲欧美日韩精品| 久久精品国产亚洲精品| 欧美伦理视频网站| 一区二区三区视频免费在线观看| 欧美午夜国产| 国产欧美日韩精品a在线观看| 欧美视频手机在线| 国产欧美精品va在线观看| 国产主播精品| 一卡二卡3卡四卡高清精品视频| 亚洲影视九九影院在线观看| 久久综合精品一区| 亚洲精品免费网站| 午夜日韩视频| 欧美伦理在线观看| 激情偷拍久久| 在线中文字幕一区| 久久综合中文色婷婷| 一区二区三区欧美日韩| 久久在线视频在线| 国产精品久久久久久久免费软件| 在线欧美电影| 欧美一区2区视频在线观看| 欧美成人午夜激情| 午夜精品福利一区二区三区av | 99亚洲精品| 猛男gaygay欧美视频| 国产目拍亚洲精品99久久精品 | 欧美一区二区视频观看视频| 欧美精彩视频一区二区三区| 国产在线精品二区| 亚洲欧美日韩一区二区在线 | 久久久一区二区| 媚黑女一区二区| 亚洲午夜国产一区99re久久| 久久成人免费视频| 中文亚洲欧美| 欧美精品色综合| 亚洲人午夜精品免费| 久久久久久久欧美精品| 亚洲一区免费观看| 欧美亚日韩国产aⅴ精品中极品| 亚洲电影专区| 麻豆精品精华液| 久久精品国产亚洲一区二区三区| 国产精品福利网站| 亚洲一区二区在线看| 亚洲精品日韩一| 欧美激情视频给我| 一本大道久久a久久综合婷婷| 欧美激情久久久久| 欧美成人午夜激情视频| 亚洲欧洲另类| 亚洲区中文字幕| 欧美福利影院| 亚洲精品一区二区三区四区高清| 欧美成人免费在线视频| 狼人社综合社区| 亚洲欧洲一区二区天堂久久| 欧美激情a∨在线视频播放| 蜜桃久久av一区| 日韩一级黄色av| 日韩视频一区二区三区在线播放免费观看 | 久久精品网址| 亚洲男女自偷自拍图片另类| 国产精品欧美久久| 欧美在线观看一区二区| 中文av字幕一区| 国产自产精品| 亚洲高清在线观看一区| 欧美日韩1234| 亚洲欧美制服另类日韩| 久久成人在线| 亚洲免费观看高清完整版在线观看熊 | 久久综合给合久久狠狠色 | 亚洲人体影院| 国产精品theporn| 久久九九免费视频| 欧美大片在线看免费观看| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲一级片在线看| 在线观看欧美成人| 99视频一区二区| 怡红院av一区二区三区| 日韩午夜剧场| 伊人久久噜噜噜躁狠狠躁 | 黄色成人在线观看| 亚洲国产日韩欧美在线99 | 亚洲一区二区三区在线| 一区在线播放| 日韩一区二区精品| 精品99一区二区三区| 亚洲精品久久久一区二区三区| 国产麻豆视频精品| 亚洲另类在线视频| 激情视频一区二区三区| 亚洲夜间福利| 洋洋av久久久久久久一区| 欧美一级视频精品观看| 亚洲影音一区| 欧美精品在线观看| 免费国产一区二区| 国产欧美在线观看一区| 一本色道久久加勒比88综合| 最新国产成人av网站网址麻豆| 欧美一区免费| 欧美一区影院| 国产精品福利在线观看网址| 亚洲精品一区二区三区av| 雨宫琴音一区二区在线| 性欧美1819sex性高清| 午夜精品影院在线观看| 欧美精品一区二区三区蜜臀| 欧美大片在线观看一区二区| 国产一区二区三区免费观看 | 午夜在线视频一区二区区别| 一区二区三区高清视频在线观看| 久久中文字幕一区| 久久亚洲综合| 在线精品国精品国产尤物884a| 性色av一区二区三区红粉影视| 亚洲欧美国产日韩天堂区| 欧美日韩123| 一区二区福利| 亚洲永久在线观看| 国产精品地址| 新狼窝色av性久久久久久| 欧美综合国产| 激情欧美日韩| 免费在线观看精品| 亚洲欧美激情一区二区| 激情综合色综合久久| 一区二区日韩| 一本色道久久88综合亚洲精品ⅰ| 欧美福利在线| 亚洲免费电影在线| 午夜精品久久久久久| 国产精品久久国产愉拍| 亚洲午夜一二三区视频| 欧美中文字幕不卡| 在线 亚洲欧美在线综合一区| 久久久久久久一区| 欧美激情一区二区久久久| 99精品欧美| 国产精品狠色婷| 欧美一区二区三区日韩视频| 韩国自拍一区| 狼狼综合久久久久综合网 | 夜夜嗨av一区二区三区| 欧美日韩激情网| 国产精品99久久不卡二区| 欧美一区二区女人| 在线观看亚洲| 欧美日韩亚洲另类| 亚洲主播在线| 欧美大片在线观看一区| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 国产精品成人v| 午夜精彩国产免费不卡不顿大片| 欧美一区二区| 亚洲电影在线看| 欧美色欧美亚洲高清在线视频| 欧美一级在线播放| 最近中文字幕日韩精品| 欧美一区二区精品| 亚洲人成在线播放| 国产日韩一区二区三区在线播放| 欧美mv日韩mv国产网站| 亚洲欧美日韩在线| 91久久精品久久国产性色也91 | 亚洲激情网站免费观看| 国产精品第一区| 狂野欧美性猛交xxxx巴西| 亚洲一本大道在线| 亚洲电影欧美电影有声小说| 亚洲欧美日韩一区二区三区在线观看| 亚洲第一福利社区| 国产日韩精品视频一区| 欧美日韩播放| 美女在线一区二区| 久久www免费人成看片高清| 99国产精品久久久| 欧美国产日韩一区| 久久久夜精品| 午夜精品一区二区三区在线 | 美女网站久久| 欧美在线视频不卡| 亚洲影院免费观看| 夜夜嗨av一区二区三区网页| 一区二区在线不卡| 国产日韩亚洲欧美精品| 国产精品久久久久久久久久久久久| 欧美激情一区二区久久久| 蜜桃精品一区二区三区| 久久午夜视频| 久久久欧美一区二区|