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

Onway

我是一只菜菜菜菜鳥...
posts - 61, comments - 56, trackbacks - 0, articles - 34

pku 3211 Washing Clothes 0-1背包

Posted on 2010-08-03 22:23 Onway 閱讀(262) 評論(0)  編輯 收藏 引用 所屬分類: 傷不起的ACM

前幾天剛學0-1背包的時候就看過了這題,但沒什么思路,今天算是學過了三種背包了,再看回這題,還是沒什么思路。怎么人家都說是0-1背包呢,想了很久還是不知道怎么背包法,笨死。無奈看了discuss,豁然開朗。原來背包還可以這樣玩,太有意思了。

 

題意:

有一堆衣服,多種顏色,每種顏色的可能有多件。有兩個洗衣服速度相同的人要洗干凈這堆衣服。每件衣服都有一個洗干凈所要花費的時間。兩個人同時工作,但只有一種顏色的衣服都洗完后,兩人才可以開始洗其他顏色。問這兩個人洗完這堆衣服最少需要多少時間。

 

思路:將某種顏色的時間之和的一半作為0-1背包的容量,物品的價值與重量等同于該種顏色的衣服所花費的時間,這是關鍵思路啊!只要求得這個背包的能獲得的最大價值,就是說在這一半的時間里,有多少是被最有效利用的。然后總時間減去這個有效利用的,就是洗完這堆衣服最少要花費的時間。

 

要處理這個題的輸入可能比較麻煩。將輸入的數據轉化為要進行背包的數據后,背包部分就簡單了。

 

如果,這個題改一下,要分兩行輸出沒人要洗的衣服呢?又怎么處理了?

 1#include <iostream>
 2#include <string>
 3#include <algorithm>
 4using namespace std;
 5const int MAX=50000;  //變成兩個背包以后,一個的容量最多就是50000
 6char name[150];     //這個沒什么用,就是吃掉那一行的名字輸入
 7int sum[10];        //每一種顏色的時間之和
 8struct clother
 9{
10    int tim;
11    string color;
12}
clo[100];
13int data[12][100];    //將原來讀入的數據轉化后好進行0-1背包
14int dp[10][MAX+1];    //不解析
15bool cmp(clother a,clother b)
16{return a.color<b.color;}
17
18int main()
19{
20    int m,n;
21    while(cin>>m>>n&&(n||m))
22    {
23        getchar();
24        cin.getline(name,150);
25        int i,j,k;
26        for(i=1;i<=n;++i)
27            cin>>clo[i].tim>>clo[i].color;
28        sort(clo+1,clo+1+n,cmp);         //輸入完以后馬上排序
29        
30        data[1][1]=clo[1].tim;
31        for(i=2,j=1,k=2;i<=n;++i)      //data[j][0]是記錄第j種顏色的衣服件數
32            if(clo[i].color==clo[i-1].color)
33                data[j][k++]=clo[i].tim;
34            else
35            {
36                data[j][0]=--k;
37                ++j;
38                k=2;
39                data[j][1]=clo[i].tim;
40            }

41        data[j][0]=--k;
42        n=j;     //n變成了需要進行背包的顏色種數
43                //這一段很容易理解,但可能處理比較麻煩,從排序后的第二個數據,即i=2開始
44                //感覺這樣比較好處理
45
46        memset(sum,0,sizeof(sum));   //這段是數據轉化后進行時間之和統計
47        for(i=1;i<=n;++i)
48        {
49            for(j=1;j<=data[i][0];++j)
50                sum[i]+=data[i][j];
51        }

52
53        memset(dp,0,sizeof(dp));   //這一段就是進行0-1背包了
54        for(i=1;i<=n;++i)
55            for(j=1;j<=data[i][0];++j)
56                for(k=MAX;k>=data[i][j];--k)
57                    dp[i][k]=dp[i][k]>dp[i][k-data[i][j]]+data[i][j]?
58                    dp[i][k]:dp[i][k-data[i][j]]+data[i][j];
59
60        for(i=1;i<=n;++i)
61            sum[i]-=dp[i][sum[i]/2];  
62                //摘自poj discuss TangMing 的一句話:
63                //把sum[i]/2的背包最大填滿,第i種顏色耗時就為 sum[i]-dp[sum[i]/2];
64                //雖然這段代碼很短,但是整個思路的關鍵
65
66        for(i=1;i<=n;++i)
67            sum[0]+=sum[i];
68        cout<<sum[0]<<endl;
69    }

70    return 0;
71}
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久国内精品自在自线400部| 亚洲国产成人av| 欧美理论片在线观看| 久久久一区二区三区| 久久成人免费日本黄色| 午夜一区二区三区在线观看| 亚洲中午字幕| 欧美专区一区二区三区| 久久精品人人做人人综合| 久久久精品五月天| 欧美成在线观看| 欧美日本成人| 国产色综合久久| 亚洲第一成人在线| 亚洲美女电影在线| 国产日韩av高清| 一色屋精品视频免费看| 亚洲人成人77777线观看| 欧美华人在线视频| 亚洲国产精品va在线看黑人动漫| 宅男噜噜噜66一区二区 | 欧美在线观看一区二区三区| 亚洲欧洲日夜超级视频| 欧美不卡视频一区发布| 亚洲大片精品永久免费| 亚洲卡通欧美制服中文| 亚洲日本中文字幕| 欧美日韩另类在线| 亚洲午夜久久久久久久久电影院 | 免费欧美在线视频| 日韩视频二区| 久热国产精品视频| 亚洲精品国产日韩| 国产综合色在线视频区| 欧美日韩一区在线视频| 欧美日韩免费高清一区色橹橹| 亚洲欧美日韩电影| 亚洲日本激情| 欧美淫片网站| 91久久综合| 欧美在线视屏| 欧美视频在线免费看| 亚洲欧洲日产国产网站| 午夜电影亚洲| 亚洲乱码精品一二三四区日韩在线 | 久久综合激情| 久久精品视频免费观看| 亚洲在线视频免费观看| 欧美一区二区三区久久精品茉莉花| 美女在线一区二区| 亚洲激情精品| 亚洲欧洲在线看| 久久久久久999| 国产午夜精品全部视频播放| 一本一本久久| 亚洲国产日韩一区| 欧美91视频| 一区久久精品| 美女亚洲精品| 久久久精品性| 亚洲国产精彩中文乱码av在线播放| 午夜视频在线观看一区二区三区| 亚洲精品日韩在线观看| 欧美日韩高清在线观看| 夜夜嗨av一区二区三区网页| 免费久久精品视频| 久久综合久久久久88| 韩日成人在线| 国产自产在线视频一区| 亚洲激情午夜| 亚洲精品久久| 欧美日韩另类视频| 亚洲欧美精品一区| 亚洲特级毛片| 国内精品久久久| 欧美不卡一区| 欧美日韩一区二区三区高清| 亚洲免费人成在线视频观看| 亚洲女与黑人做爰| 狠狠干成人综合网| 最新亚洲一区| 国产精品美女www爽爽爽视频| 欧美伊人久久大香线蕉综合69| 中文国产成人精品久久一| 国产日韩欧美精品综合| 另类专区欧美制服同性| 欧美凹凸一区二区三区视频| 一区二区不卡在线视频 午夜欧美不卡在 | 久久免费高清| 最近中文字幕日韩精品 | 欧美一二三视频| 久久国产精品久久w女人spa| 亚洲成色777777女色窝| 亚洲免费观看高清完整版在线观看熊 | 亚洲欧美日本在线| 国产小视频国产精品| 欧美一区二区成人6969| 国产伦精品一区二区三区免费| 国产精品porn| 亚洲黄色视屏| 欧美大片在线影院| 一本高清dvd不卡在线观看| 亚洲精品一级| 亚洲欧美中日韩| 欧美激情亚洲激情| 亚洲国产成人久久综合一区| 亚洲欧美偷拍卡通变态| 亚洲精品免费在线| 激情六月婷婷久久| 亚洲欧美日韩网| 欧美激情亚洲自拍| 久久精品亚洲精品| av成人毛片| 国产欧美在线观看| 午夜亚洲伦理| 久久久久久综合| 国产精品乱码一区二三区小蝌蚪| 美女日韩在线中文字幕| 国产伦一区二区三区色一情| 久久av一区二区| 亚洲欧美成人一区二区在线电影 | 激情一区二区三区| 欧美日韩精品一区二区三区四区 | 9久re热视频在线精品| 久久亚洲一区| 欧美专区日韩专区| 欧美黄色免费网站| 欧美日韩国产影片| 91久久亚洲| 国产精品99久久99久久久二8| 欧美色123| 亚洲国产另类久久久精品极度| 在线视频欧美日韩| 一本一本久久| 国产精品亚洲激情| 伊人婷婷久久| 亚洲一区日韩| 久久久亚洲高清| 欧美一区二区免费| 欧美sm视频| 国产精品成人在线观看| 国产精品久久久久三级| 亚洲电影第三页| 欧美一级欧美一级在线播放| 久久激情婷婷| 在线亚洲欧美| 久久av资源网| 欧美呦呦网站| 欧美国产视频在线观看| 影音先锋日韩资源| 先锋影音一区二区三区| 欧美 日韩 国产 一区| 美女精品视频一区| 老司机一区二区三区| 久久本道综合色狠狠五月| 久久综合国产精品台湾中文娱乐网 | 亚洲美女av网站| 亚洲欧美偷拍卡通变态| 久久亚洲视频| 亚洲春色另类小说| 91久久夜色精品国产九色| 欧美激情一区二区三区在线| 久久综合九色99| 亚洲黄网站在线观看| 一区二区亚洲欧洲国产日韩| 午夜在线精品| 麻豆精品在线观看| 欧美激情亚洲自拍| 亚洲成色www8888| 国产精品日韩在线观看| 99精品99久久久久久宅男| 亚洲午夜视频在线| 亚洲大片精品永久免费| 久久国产精品一区二区三区四区| 欧美剧在线观看| 久久精品在这里| 亚洲无吗在线| 国产一区二区三区四区三区四| 欧美亚洲一区二区三区| 欧美成年人网站| 在线一区欧美| 国一区二区在线观看| 欧美日韩国产va另类| 欧美一级在线播放| 亚洲七七久久综合桃花剧情介绍| 夜夜嗨av色一区二区不卡| 国产亚洲激情在线| 欧美极品在线视频| 久久精品欧美| 亚洲一二三四区| 亚洲国产天堂久久综合网| 欧美一区二区三区另类| 最新成人av在线| 国产午夜精品在线| 欧美性大战久久久久| 欧美 日韩 国产在线| 欧美一区二区三区免费在线看| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美一区二区视频在线观看2020| 亚洲精品国产无天堂网2021|