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

            糯米

            TI DaVinci, gstreamer, ffmpeg
            隨筆 - 167, 文章 - 0, 評論 - 47, 引用 - 0
            數據加載中……

            POJ 1837 Balance 動態規劃

            思路:

            力矩 = 力臂*重量。這個高中物理學過啦,呵呵。
            所以如果現在有一個 3 放在 -5 的位置上,一個 4 放在 3 的位置上,那當前天平的總力矩就是 3*-5 + 4*3 = -3 了

            動態規劃:
            從小到大依次放 weight。
            f[i][j] = { 已經放了 i 個 weight,天平的總力矩為 j 時候的方案個數 }
            初始化 f[0][0] = 1
            狀態轉移:
            對每個位置 x
               f[i + 1][j + W[i + 1]*x] += f[i][j]

            #include <stdio.h>
            #include 
            <stdlib.h>

            int C, G, X[24], W[24];
            struct {
                
            int val, tm;
            }
             _dp[2][1 << 15], *dp[2= {
                
            &_dp[0][_countof(_dp[0]) / 2],
                
            &_dp[1][_countof(_dp[1]) / 2],
            }
            *cur, *pre;
            int up, down;

            int main()
            {
                
            int i, j, k, y;

                freopen(
            "e:\\test\\in.txt""r", stdin);

                scanf(
            "%d%d"&C, &G);
                
            for (i = 1; i <= C; i++)
                    scanf(
            "%d"&X[i]);
                
            for (i = 1; i <= G; i++)
                    scanf(
            "%d"&W[i]);

                dp[
            1][0].tm = 1;
                dp[
            1][0].val = 1;
                
            for (i = 1; i <= G; i++{
                    pre 
            = dp[i & 1];
                    cur 
            = dp[(i + 1& 1];
                    
            for (j = down; j <= up; j++{
                        
            if (pre[j].tm != i)
                            
            continue;
                        
            for (k = 1; k <= C; k++{
                            y 
            = j + W[i]*X[k];
                            
            if (cur[y].tm != i + 1{
                                cur[y].tm 
            = i + 1;
                                cur[y].val 
            = 0;
                            }

                            cur[y].val 
            += pre[j].val;
                            
            if (y < down)
                                down 
            = y;
                            
            if (y > up)
                                up 
            = y;
                        }

                    }

                }

                printf(
            "%d\n", cur[0].val);
                

                
            return 0;
            }

            posted on 2010-04-22 21:50 糯米 閱讀(135) 評論(0)  編輯 收藏 引用 所屬分類: POJ

            久久久久九九精品影院| 热久久国产精品| 亚洲精品蜜桃久久久久久| 亚洲精品无码久久久久sm| 99久久精品毛片免费播放| 国产成人久久激情91| 久久夜色精品国产| 久久精品国产99久久久古代| 婷婷五月深深久久精品| 久久国产精品一区| 久久无码国产专区精品| 成人免费网站久久久| 色综合久久久久综合99| 国产成人精品久久二区二区| 亚洲国产成人久久综合区| 99久久久精品免费观看国产| 亚洲国产成人精品91久久久 | 久久久久亚洲av无码专区喷水 | 人妻精品久久久久中文字幕69| 国产综合久久久久| A级毛片无码久久精品免费| 久久国产影院| 国产精品伦理久久久久久| 精品久久久无码人妻中文字幕| 久久乐国产精品亚洲综合| 国产综合久久久久| 久久亚洲精品成人无码网站| 久久涩综合| 久久成人18免费网站| 国产成人久久久精品二区三区| 久久99精品久久久久久动态图| 久久久久久久久波多野高潮| 亚洲国产精品嫩草影院久久| 久久精品国产清自在天天线| 国产成人无码精品久久久免费| 99久久免费国产特黄| 老色鬼久久亚洲AV综合| 一本色道久久88—综合亚洲精品| 久久伊人五月丁香狠狠色| 久久精品极品盛宴观看| 亚洲国产成人久久综合一区77|