• <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>
            心如止水
            Je n'ai pas le temps
            posts - 400,comments - 130,trackbacks - 0
             

            極度郁悶地完成了這一題……倒不是因?yàn)槊质?#8220;情敵”,而是我的測(cè)評(píng)系統(tǒng)似乎出了問(wèn)題,導(dǎo)致我一直60分。后來(lái)把文件復(fù)制一份,新建文件夾,重新測(cè)評(píng),100!當(dāng)時(shí)快氣爆了!

            此題的方法是搜索+DP

            如果忽略“超級(jí)情敵”不管,發(fā)現(xiàn)這是個(gè)二維費(fèi)用的背包。超級(jí)情敵最多有4個(gè),有三種情況:不消滅,第1月消滅,第2月消滅,先搜索這些情況,再DP

            以下是我的代碼。

            #include<stdio.h>
            #define maxn 51
            #define maxab 101
            typedef unsigned __int64 int64;
            FILE 
            *fin,*fout;
            int a,b,n,m,p[maxn]={0},num[5],flag[5],super[maxn]={0};
            long w[maxn],t[maxn];
            int64 d[maxn][maxab][maxab],ans,sum;
            void init()
            {
                
            int i,j,x,tot;
                sum
            =0;
                ans
            =0;
                fin
            =fopen("rival.in","r");
                fscanf(fin,
            "%d%d",&a,&b);
                fscanf(fin,
            "%d%d",&n,&m);
                
            for(i=1;i<=n;i++)
                
            {
                   fscanf(fin,
            "%ld%ld",&w[i],&t[i]);
                   sum
            +=w[i];
                }

                
            for(i=1;i<=m;i++)
                
            {
                   fscanf(fin,
            "%d%d",&num[i],&tot);
                   super[num[i]]
            =1;
                   
            for(j=1;j<=tot;j++)
                   
            {
                     fscanf(fin,
            "%d",&x);
                      p[x]
            =i;
                   }

                }

                fclose(fin);
            }

            void dp(int t1,int t2,int64 now)
            {
                
            int i,j,k;
                int64 last
            =0;
                
            for(i=1;i<=n;i++)
                  
            for(j=0;j<=t1;j++)
                    
            for(k=0;k<=t2;k++)
                      d[i][j][k]
            =0;
                
            for(i=1;i<=n;i++)
                  
            for(j=0;j<=t1;j++)
                    
            for(k=0;k<=t2;k++)
                    
            {
                       d[i][j][k]
            =d[i-1][j][k];

                       
            if(!super[i])
                       
            {
                          
            if((p[i]==0||flag[p[i]]<=1)&&j>=t[i]&&d[i-1][j-t[i]][k]+w[i]>d[i][j][k])
                            d[i][j][k]
            =d[i-1][j-t[i]][k]+w[i];
                          
            if((p[i]==0||flag[p[i]]<=2)&&k>=2*t[i]&&d[i-1][j][k-2*t[i]]+w[i]>d[i][j][k])
                            d[i][j][k]
            =d[i-1][j][k-2*t[i]]+w[i];
                       }

                       
            if(d[i][j][k]>last) last=d[i][j][k];
                    }

                
            if(now+last>ans) ans=now+last;
            }

            void dfs(int dep,int t1,int t2,int64 now)
            {
                
            if(dep>m)
                
            {
                   dp(t1,t2,now);
                   
            return;
                }

                
            if(t1>=t[num[dep]])
                
            {
                   flag[dep]
            =1;
                   dfs(dep
            +1,t1-t[num[dep]],t2,now+w[num[dep]]);
                }

                
            if(t2>=2*t[num[dep]])
                
            {
                   flag[dep]
            =2;
                   dfs(dep
            +1,t1,t2-2*t[num[dep]],now+w[num[dep]]);
                }

                flag[dep]
            =3;
                dfs(dep
            +1,t1,t2,now);
            }

            void write()
            {
                fout
            =fopen("rival.out","w");
                fprintf(fout,
            "%I64d\n",sum-ans);
                fclose(fout);
            }

            int main()
            {
                init();
                dfs(
            1,a,b,0);
                write();
            return 0;
            }

            posted on 2010-01-06 19:39 lee1r 閱讀(181) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 題目分類(lèi):動(dòng)態(tài)規(guī)劃
            久久久国产99久久国产一| 久久AV高潮AV无码AV| 久久综合久久自在自线精品自| 欧美亚洲日本久久精品| 久久综合五月丁香久久激情| 99久久精品日本一区二区免费| 久久免费高清视频| 久久激情五月丁香伊人| 久久人妻少妇嫩草AV蜜桃| 精产国品久久一二三产区区别 | 亚洲精品无码久久久| 色偷偷偷久久伊人大杳蕉| 狠狠人妻久久久久久综合| 77777亚洲午夜久久多喷| 久久人妻AV中文字幕| 国产高清国内精品福利99久久| 综合久久国产九一剧情麻豆| 国产精品日韩欧美久久综合| 国产精品99精品久久免费| 亚洲精品乱码久久久久66| 亚洲欧美一区二区三区久久| 亚洲国产精品久久久久网站| 亚洲成人精品久久| 久久综合久久综合久久综合| 久久99精品国产99久久| 久久久久久精品无码人妻| 大蕉久久伊人中文字幕| 久久ZYZ资源站无码中文动漫| 久久频这里精品99香蕉久| 久久夜色撩人精品国产| 99久久精品免费看国产免费| 亚洲国产精品无码久久98| 欧美午夜精品久久久久久浪潮| 九九热久久免费视频| 久久99精品久久久久久噜噜| 国产精品99久久久久久猫咪| 久久久久国色AV免费看图片| 欧美伊人久久大香线蕉综合69| 亚洲精品乱码久久久久久不卡| 久久综合久久美利坚合众国| 色婷婷综合久久久久中文|