• <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>

            Climber.pI的OI之路

            Through the darkest dark,may we see the light.

            NOIp 2006 金明的預算方案

            題目中附件不超過2個,因而主附件存在4種不同的存取情況,可以轉化為分組背包問題.
            [狀態]f[k][v]表示添加前k組物品,剩余空間為v時的最大值
            [方程]f[k][v] = max{f[k-1][v], f[k-1][v-c[i]]+w[i]}

            注意循環順序.(參見《背包九講》)

            需要注意的問題(2次WA):
            1.仔細讀題,確定編號對應的物品.
            2.注意到方程中的參數非負(背包類問題需注意).

             1 #include<stdio.h>
             2 #include<string.h>
             3 #include<iostream>
             4 using namespace std;
             5 int c[65][4], w[65][4], f[32000], set[70] = {0};
             6 int max(int a, int b){return a > b ? a : b;}
             7 int main(){
             8     int n, m, v, p, q, i, j, t = 0;
             9     FILE *fout = fopen("budget.out", "w");
            10     memset(c, -1, sizeof(c));
            11     memset(w, -1, sizeof(w));
            12     memset(f, 0, sizeof(f));
            13     scanf("%d%d", &n, &m);
            14     for (i = 0; i < m; i++){
            15         scanf("%d%d%d", &v, &p, &q);
            16         j = 0;
            17         if (!q) {
            18             c[++t][0] = v;
            19             w[t][0] = v*p;
            20             set[i+1] = t;
            21         }
            22         else{
            23             q = set[q];
            24             if (w[q][1] == -1){
            25                 //printf("dgfdgds\n");
            26                 c[q][1] = c[q][0] + v;
            27                 w[q][1] = w[q][0] + v*p; 
            28             }
            29             else if (w[q][2] == -1){
            30                 c[q][2] = c[q][0] + v;
            31                 w[q][2] = w[q][0] + v*p; 
            32                 c[q][3] = c[q][1] + v;
            33                 w[q][3] = w[q][1] + v*p; 
            34             }
            35         }
            36     }
            37     for (i = 1; i <= t; i++)
            38         for (v = n; v >= 0; v--)
            39             for (j = 0; j < 4; j++)
            40                 if (c[i][j] != -1 && v-c[i][j] >= 0){
            41                     f[v] = max(f[v], f[v-c[i][j]]+w[i][j]);
            42                 }
            43     printf("%d\n", f[n]);
            44 }
            45 


            posted on 2010-10-05 10:11 Climber.pI 閱讀(489) 評論(0)  編輯 收藏 引用 所屬分類: 動態規劃

            久久这里有精品视频| 久久精品中文字幕一区| 亚洲美日韩Av中文字幕无码久久久妻妇 | 久久久亚洲欧洲日产国码是AV| 久久久久99精品成人片三人毛片| 久久国产精品波多野结衣AV| 少妇高潮惨叫久久久久久| 国产日产久久高清欧美一区| 久久无码国产| 久久A级毛片免费观看| 久久久精品久久久久影院| 久久精品亚洲精品国产色婷| 久久婷婷国产麻豆91天堂| 色综合久久久久综合体桃花网| 日韩亚洲欧美久久久www综合网 | 99久久国产综合精品麻豆| 久久亚洲精品国产精品婷婷| 久久亚洲AV成人无码国产 | 久久青草国产精品一区| 久久精品综合网| 久久久久久久久久免免费精品| 久久免费的精品国产V∧| 欧美午夜精品久久久久久浪潮| 一本色道久久88加勒比—综合| 久久99精品久久久久久久久久 | 久久精品国产亚洲综合色| 伊人久久大香线蕉综合影院首页| 久久久WWW成人免费精品| 久久久久久久久无码精品亚洲日韩| 久久久久无码精品国产app| 韩国无遮挡三级久久| 国产精品女同久久久久电影院| 欧美亚洲国产精品久久| 亚洲国产精品无码久久久久久曰| 亚洲午夜精品久久久久久人妖| 国产亚洲欧美精品久久久| 久久亚洲精品中文字幕| 亚洲国产精品久久电影欧美| 欧美亚洲色综久久精品国产| 久久久精品国产免大香伊| 中文字幕久久精品无码|