• <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 糯米 閱讀(138) 評論(0)  編輯 收藏 引用 所屬分類: POJ

            国产精品无码久久久久| 久久国产综合精品五月天| 久久婷婷五月综合成人D啪| 亚洲国产一成久久精品国产成人综合 | 香蕉久久一区二区不卡无毒影院| 精品国产一区二区三区久久| 久久国产精品视频| 久久久噜噜噜久久熟女AA片| 999久久久免费国产精品播放| 欧美精品九九99久久在观看| 亚洲精品成人久久久| 婷婷久久久亚洲欧洲日产国码AV | 内射无码专区久久亚洲| 久久久国产精品亚洲一区| 久久最新免费视频| 亚洲精品高清久久| 久久天堂AV综合合色蜜桃网| 久久毛片免费看一区二区三区| 久久夜色精品国产噜噜麻豆| 久久国内免费视频| 国产精品日韩欧美久久综合| 久久99国产综合精品女同| 中文字幕日本人妻久久久免费| 国产AV影片久久久久久| 久久99国产精品久久久| 久久大香香蕉国产| 狠狠色婷婷久久综合频道日韩 | 亚洲国产精品成人久久| 久久精品国产清自在天天线| 久久国产精品二国产精品| 嫩草影院久久99| 国产美女久久久| 亚洲精品高清久久| 久久99精品国产麻豆婷婷| 久久青青草原精品影院| 久久综合久久综合久久| 久久精品一区二区国产| www亚洲欲色成人久久精品| 老司机国内精品久久久久| 热久久这里只有精品| 国产视频久久|