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

Omni Inspirations

problems & programs ~

統(tǒng)計(jì)

留言簿

Friends

閱讀排行榜

評(píng)論排行榜

【除草】Baltic OI 2010 day2 candies

很久沒寫了。。。

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

做法:
這個(gè)題我做了一晚上加一上午!!

猜想:
換一個(gè)物品 等價(jià)于 先去掉這個(gè)物品做N-1個(gè)物品 最后加入一個(gè)物品并更新
(寫了個(gè)暴力  是符合的)
然后就將問題變?yōu)榱苏嬲膬蓡枺?br>第一問,求X使得除了X的N-1個(gè)物品能得到的種數(shù)Ans'最大
(因?yàn)樽罱K方案一樣 所以得刪一個(gè)最沒用的)
第二問,添加一個(gè)物品 使得最后得到的最大

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

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

對(duì)于第二問   事實(shí)上我們可以發(fā)現(xiàn)  添加Y=(∑Ai)-X+1這個(gè)物品是肯定可以將方案數(shù)增加最多的 因?yàn)?br>假設(shè)用N-1個(gè)物品能得到的裝箱數(shù)組是
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必然是一個(gè)使方案最大可行解 亦可能是最優(yōu)解
所以我們?nèi)绻乙粋€(gè)比Y更優(yōu)的解 必然要滿足原本擁有的所有解加上Y'    原本都不可行!

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

【我的做法
先預(yù)處理前綴和  即從1開始到i能拼成的個(gè)數(shù)
先把這個(gè)枚舉加些剪枝 將原來拼不成的重量進(jìn)行枚舉
再?gòu)倪@些拼不成的重量里枚舉X   因?yàn)閰^(qū)間背包算出來的是許多個(gè)區(qū)間 最后枚舉這些區(qū)間
對(duì)于一個(gè)區(qū)間[a,b] 如果X是可行的那必然有 sum(a+X,b+X)=0】

事實(shí)上這么做居然就過了!因?yàn)閰^(qū)間數(shù)不太多 我能構(gòu)造的最牛逼的數(shù)據(jù) 也只能 O(300000*5000) 這個(gè)還是勉強(qiáng)能跑過的
對(duì)于官方數(shù)據(jù) 每個(gè)點(diǎn)都能在0.2s內(nèi)跑過!!

這樣終于AC了此題!!

(另外求標(biāo)準(zhǔn)的優(yōu)美的算法!!!!!!!!!)

  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) 評(píng)論(2)  編輯 收藏 引用 所屬分類: Mix

評(píng)論

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

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

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

@jiakai
對(duì) 這是個(gè)人品算法 所以求標(biāo)準(zhǔn)算法  回復(fù)  更多評(píng)論   


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久综合狠狠综合久久综青草| 国产乱肥老妇国产一区二 | 免费高清在线一区| 午夜一区二区三区在线观看| 亚洲欧洲精品一区二区三区不卡| 老色鬼精品视频在线观看播放| 久久青青草原一区二区| 久久久亚洲人| 免费人成网站在线观看欧美高清| 免费成人黄色片| 亚洲国产经典视频| 亚洲深夜影院| 久久国产精品久久久久久久久久 | 亚洲欧美成人一区二区三区| 亚洲永久免费观看| 性亚洲最疯狂xxxx高清| 久久久免费av| 亚洲国产婷婷香蕉久久久久久99 | 亚洲国产日韩欧美| 亚洲一区二区免费看| 欧美在线视屏| 欧美日本精品| 国内精品久久久久伊人av| 亚洲大片在线| 亚洲欧美日韩精品久久| 麻豆精品一区二区av白丝在线| 亚洲区国产区| 久久国产一区| 国产精品九九| 99精品欧美一区二区三区| 久久精品一区四区| 99在线精品观看| 蜜桃av一区二区| 国产日产亚洲精品| 亚洲午夜久久久久久久久电影网| 欧美va亚洲va日韩∨a综合色| 亚洲视频香蕉人妖| 欧美精品日本| 亚洲第一在线视频| 久久影视精品| 亚洲在线日韩| 欧美涩涩网站| 99在线热播精品免费| 久久久www成人免费无遮挡大片| 亚洲精品社区| 欧美成年网站| 在线免费一区三区| 久久精品亚洲热| 亚洲精品久久久久| 一区二区日韩欧美| 亚洲综合色丁香婷婷六月图片| 嫩草国产精品入口| 欧美亚洲日本网站| 国产精品亚洲аv天堂网| 99精品国产热久久91蜜凸| 欧美不卡福利| 久久中文精品| 亚洲国产女人aaa毛片在线| 久久综合色播五月| 久久经典综合| 国产视频精品网| 欧美中文字幕精品| 先锋影音久久| 国内精品嫩模av私拍在线观看 | 久久精品视频在线观看| 中文亚洲免费| 国产精品一区二区你懂的| 亚洲欧美综合| 亚洲欧美日韩成人高清在线一区| 国产精品推荐精品| 久久精品综合网| 久久影音先锋| 99精品久久久| 亚洲欧美一区二区在线观看| 国产综合色在线| 欧美mv日韩mv亚洲| 欧美精品综合| 羞羞漫画18久久大片| 欧美在线视频一区二区三区| 亚洲电影天堂av| 亚洲日本无吗高清不卡| 欧美色中文字幕| 久久全国免费视频| 欧美黄色一区| 午夜精品免费| 久久久亚洲欧洲日产国码αv| 亚洲日本成人网| 中国成人在线视频| 狠狠色丁香婷婷综合影院| 奶水喷射视频一区| 欧美午夜在线一二页| 久久久亚洲人| 国产精品久久二区二区| 免费成人高清视频| 国产精品美女主播| 欧美成在线视频| 国产精品天天看| 亚洲欧洲精品成人久久奇米网| 国产欧美精品| 亚洲精品免费一二三区| 国产日韩欧美成人| 亚洲精品一区二区三区婷婷月| 国产午夜精品全部视频播放| 亚洲人成小说网站色在线| 国内外成人在线| 一区二区三区视频在线观看| 亚洲国产高清一区二区三区| 正在播放亚洲| 免费亚洲一区| 亚洲福利专区| 欧美在线视频二区| 亚洲欧美日韩一区二区| 嫩草成人www欧美| 久久动漫亚洲| 国产精品福利在线| 最新成人av网站| 亚洲第一福利社区| 久久精品午夜| 久久精品中文字幕免费mv| 欧美亚州一区二区三区| 亚洲激情另类| 亚洲毛片在线观看| 欧美成人午夜77777| 免费成人高清视频| 亚洲第一区在线| 久久九九免费| 久久久人人人| 悠悠资源网亚洲青| 欧美一二三区精品| 欧美中文字幕在线| 国产欧美日韩视频一区二区三区| 一区二区国产在线观看| 亚洲精品激情| 欧美精品123区| 亚洲精品日本| aⅴ色国产欧美| 欧美日韩一级黄| 9国产精品视频| 亚洲欧美另类久久久精品2019| 欧美系列精品| 性欧美8khd高清极品| 欧美在线综合| 尤物yw午夜国产精品视频| 久久精品亚洲精品国产欧美kt∨| 久久xxxx精品视频| 国产一区二区三区成人欧美日韩在线观看 | 亚洲蜜桃精久久久久久久| 久久久久久97三级| 久久久亚洲影院你懂的| 韩国精品在线观看| 久久精品亚洲乱码伦伦中文 | 久久久久久久一区二区三区| 久热精品视频在线观看| 黑丝一区二区| 久久动漫亚洲| 亚洲国产精品电影在线观看| 一区二区三区成人精品| 国产精品婷婷午夜在线观看| 久久国产精品久久久| 亚洲国产免费看| 亚洲欧美制服中文字幕| 国色天香一区二区| 欧美人成在线视频| 亚洲欧美日韩精品久久久| 免费成人高清| 亚洲欧美中文在线视频| 永久555www成人免费| 欧美日本在线| 欧美一区二区三区免费大片| 欧美不卡视频一区发布| 亚洲欧美一区二区在线观看| 国产精品视频网站| 亚洲七七久久综合桃花剧情介绍| 中文在线不卡| 国产一区二区三区无遮挡| 欧美mv日韩mv国产网站app| 亚洲毛片一区| 老色鬼精品视频在线观看播放| 亚洲久色影视| 国产一区二区三区在线观看免费视频| 久久中文字幕导航| 一区二区日本视频| 欧美福利精品| 欧美一二三区精品| 亚洲美女免费精品视频在线观看| 国产欧美日韩一区二区三区在线观看 | 欧美成人激情在线| 亚洲午夜视频在线| 欧美国产日韩在线| 欧美专区18| 亚洲一区二区日本| 亚洲国内自拍| 国产色视频一区| 国产精品乱码一区二区三区| 欧美风情在线观看| 久久女同互慰一区二区三区| 亚洲少妇最新在线视频| 亚洲精品乱码久久久久久蜜桃91| 美女图片一区二区| 久久亚洲精品一区|