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

            poj 3093 Margaritas on the River Walk

               這是一個(gè)動態(tài)規(guī)劃題,據(jù)說是背包問題的變形。我動態(tài)規(guī)劃做得很少,解法一直按照算法導(dǎo)論的思想分解重疊子問題。
               題意是用錢盡可能多的買物品,每種物品買一個(gè),問有多少種買法。
               我也想不出這是什么背包問題的變形,沒做過幾個(gè)背包問題,也沒看過背包九講。還是堅(jiān)持認(rèn)為正確的用狀態(tài)描述成子問題
            就一定能解題的。今天和隊(duì)友在做專題時(shí)候做到這個(gè)題,我一直做了一上午都沒出來。
               后面發(fā)現(xiàn)了個(gè)性質(zhì)就可以直接轉(zhuǎn)換為類似最簡單的背包問題了。排序物品價(jià)值,從最大物品開始分解子問題,用剩余物品數(shù)
            和錢描述問題的狀態(tài)。當(dāng)前物品是否必須取,是根據(jù)當(dāng)前的錢把剩下的物品全買了之后剩下的錢還是否大于當(dāng)前物品的價(jià)值,
            如果大于就必須買,否則可以買或者不買。

               為了正確描述問題的狀態(tài),必須事先排序價(jià)值數(shù)組,因?yàn)榕判蛑罂梢员WC不能買當(dāng)前物品的時(shí)候一定不能買前面的物品,
            那么我們對前面物品的處理就是正確的了。
            至此可以進(jìn)行最簡單的子問題分解了。到最后物品處理完之后(物品數(shù)為0),如果錢
            一點(diǎn)都沒減少,那么(0, M) = 0,否則(0, M) = 1。注意這個(gè)邊界處理,否則會wa。
               所以,需要先對價(jià)值數(shù)組排序,并計(jì)算出表示前N個(gè)物品價(jià)值和的數(shù)組。
               做不出來的時(shí)候,翻了下別人的解法,一頭霧水。看來還是算法導(dǎo)論的思想指導(dǎo)意義大多了。。。

               代碼如下:
            #include <stdio.h> 
            #include <string.h>
            #include <algorithm>
            using namespace std;
            typedef long long INT;
            INT nAns[40][1010];
            INT nValue[100];
            INT nSum[100];
            INT nN, nM;

            INT GetAns(INT nNum, INT nMoney)
            {
                if (nAns[nNum][nMoney] == -1)
                {
                    if (nNum == 0)
                    {
                        nAns[nNum][nMoney] = 1;
                        if (nMoney == nM)
                        {
                            nAns[nNum][nMoney] = 0;
                        }
                    }
                    else
                    {
                        INT nRet = 0;

                        if (nMoney - nSum[nNum - 1] >= nValue[nNum])
                        {
                            nRet = GetAns(nNum - 1, nMoney - nValue[nNum]);
                        }
                        else
                        {
                            if (nMoney >= nValue[nNum])
                            {
                                nRet += GetAns(nNum - 1, nMoney - nValue[nNum]);
                            }
                            nRet += GetAns(nNum - 1, nMoney);
                        }

                        nAns[nNum][nMoney] = nRet;
                    }
                }
                return nAns[nNum][nMoney];
            }

            int main()
            {
                INT nT;

                scanf("%I64d", &nT);
                for (INT i = 1; i <= nT; ++i)
                {
                    scanf("%I64d%I64d", &nN, &nM);
                    for (INT j = 1; j <= nN; ++j)
                    {
                        scanf("%I64d", &nValue[j]);
                    }
                    memset(nAns, -1, sizeof(nAns));
                    sort(nValue + 1, nValue + nN + 1);
                    nSum[0] = 0;
                    for (INT j = 1; j <= nN; ++j)
                    {
                        nSum[j] = nSum[j - 1] + nValue[j];
                    }
                    printf("%I64d %I64d\n", i, GetAns(nN, nM));
                }

                return 0;
            }

            posted on 2012-08-30 14:11 yx 閱讀(1373) 評論(0)  編輯 收藏 引用 所屬分類: 動態(tài)規(guī)劃


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


            <2012年5月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            導(dǎo)航

            統(tǒng)計(jì)

            公告

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            me

            好友

            同學(xué)

            網(wǎng)友

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            日韩精品无码久久久久久| 一本综合久久国产二区| 99国产欧美久久久精品蜜芽| 久久久久久久人妻无码中文字幕爆| 久久精品人人做人人爽97| 国产精品久久久久一区二区三区| 国产毛片久久久久久国产毛片| 欧美久久亚洲精品| 国产综合久久久久久鬼色| 久久嫩草影院免费看夜色| 伊人久久大香线蕉综合Av| 狠狠色伊人久久精品综合网| 精品一二三区久久aaa片| 久久久久久狠狠丁香| 久久精品桃花综合| 国产成人综合久久久久久| 久久亚洲私人国产精品vA| 久久影院久久香蕉国产线看观看| 国产精品久久久久jk制服| 女人高潮久久久叫人喷水| 亚洲国产精品久久久久久| 无码超乳爆乳中文字幕久久| 少妇被又大又粗又爽毛片久久黑人| AV无码久久久久不卡蜜桃| 99精品国产综合久久久久五月天 | 久久综合久久美利坚合众国| 91精品国产乱码久久久久久 | 久久精品国产久精国产思思| 亚洲国产成人精品91久久久| 99久久国产综合精品五月天喷水| 色欲综合久久躁天天躁蜜桃| 久久99精品国产麻豆宅宅| 亚洲国产精品一区二区三区久久 | 久久综合视频网站| 久久婷婷色综合一区二区| 国产香蕉97碰碰久久人人| 亚洲国产成人久久综合一| 色偷偷888欧美精品久久久| 久久亚洲国产精品一区二区| 女人香蕉久久**毛片精品| 精品久久久久久国产|