• <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 Za, A Za, Fighting...

            堅信:勤能補拙

            PKU 1456 Supermarket

            問題:
            http://acm.pku.edu.cn/JudgeOnline/problem?id=1456

            思路:
            這題就是個悲劇...
            都說這題是貪心,還有并查集的優(yōu)化,不過我對于貪心一直不敢用,因為不知道為什么可以貪心
            然后,那就動態(tài)規(guī)劃吧,結(jié)果,徹底受打擊了,對于動態(tài)規(guī)劃還是沒掌握啊...

            其實,用value[i][j]來表示前i件product到時刻j為止所得到的最大profit
                      value[i][j] = max (value[i-1][j], value[i-1][j-1]+profit[i])
            跟01背包的形式是一樣的,所以就可以用滾動數(shù)組進行空間優(yōu)化

            代碼:
             1 #include<stdio.h>
             2 #include<stdlib.h>
             3 #include<string.h>
             4 #define MAX_N 10001
             5 #define Max(a,b) ((a)<(b)?(b):(a))
             6 struct Prod {
             7     int profit;
             8     int deadline;
             9 } prods[MAX_N];
            10 int n, upper, value[MAX_N];
            11 
            12 int
            13 compare(const void *arg1, const void *arg2) /* ascend order: deadline */
            14 {
            15     struct Prod *= (struct Prod *)arg1;
            16     struct Prod *= (struct Prod *)arg2;
            17     return a->deadline-b->deadline;
            18 }
            19 
            20 void
            21 init()
            22 {
            23     int i;
            24     for(i=0; i<n; i++)
            25         scanf("%d %d"&prods[i].profit, &prods[i].deadline);
            26     qsort(prods, n, sizeof(struct Prod), compare);
            27     upper = prods[n-1].deadline;
            28 }
            29 
            30 void
            31 solve()
            32 {
            33     int i, j;
            34     memset(value, 0sizeof(value));
            35     for(i=0; i<n; i++) {
            36         for(j=prods[i].deadline; j>=1; j--
            37             value[j] = Max(value[j], value[j-1]+prods[i].profit);
            38         for(j=prods[i].deadline+1; j<=upper; j++)
            39             value[j] = Max(value[prods[i].deadline], value[j]);
            40     }
            41     printf("%d\n", value[upper]);
            42 }
            43 
            44 int
            45 main(int argc, char **argv)
            46 {
            47     while(scanf("%d"&n) != EOF) {
            48         init();
            49         solve();
            50     }
            51 }

            posted on 2010-09-15 16:25 simplyzhao 閱讀(206) 評論(0)  編輯 收藏 引用 所屬分類: C_動態(tài)規(guī)劃

            導航

            <2010年9月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789

            統(tǒng)計

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲伊人久久成综合人影院 | 久久国产视屏| 久久精品国产精品亚洲| 亚洲精品无码专区久久同性男| 一本色道久久88精品综合| 97久久超碰国产精品2021| 国产精品久久久天天影视香蕉| 久久AV高潮AV无码AV| 亚洲国产精品一区二区久久| 久久久久99这里有精品10 | 亚洲国产精品成人久久| 国产精品青草久久久久福利99| 亚洲综合伊人久久大杳蕉| 精品久久久久久国产免费了| 九九久久自然熟的香蕉图片| 久久婷婷五月综合国产尤物app| 亚洲国产精品人久久| 久久精品国产精品国产精品污| 国产69精品久久久久久人妻精品| 久久99精品国产麻豆蜜芽| 国产午夜免费高清久久影院| 麻豆av久久av盛宴av| 色偷偷91久久综合噜噜噜噜| 久久精品国产亚洲一区二区三区| …久久精品99久久香蕉国产 | 久久av无码专区亚洲av桃花岛| 亚洲国产成人乱码精品女人久久久不卡 | 日日狠狠久久偷偷色综合0| 老司机国内精品久久久久| 国产韩国精品一区二区三区久久| 久久精品国产亚洲AV香蕉| 久久精品国产99久久无毒不卡| 久久午夜羞羞影院免费观看| 久久丫精品国产亚洲av不卡| 亚洲国产精品无码久久久不卡 | 久久国产精品一区| 日本久久久精品中文字幕| 精品无码久久久久久久久久| 久久99精品久久久久久噜噜| 欧美久久综合九色综合| 久久99久国产麻精品66|