• <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>
            posts - 195,  comments - 30,  trackbacks - 0

            2nd JOJ Cup Online VContest Problem

            We all know that bunny is fond of carrots. One cloudy day, he was told that there would be a violenting flood coming soon to destroy the forests. He was scared and after not thinking too much he told himself that he had to escape. He suddenly recalled that there was a temple on the top of the hill and he might shelter there until the flood's past. But unfortunately there was no food for him on the top of the hill, so he had to take his carrots away along with himself. Then he moved to the foot of the hill and stopped. There was only one way for him to get the top of the hill, that is, a long staircase. Given the number of the steps of the staircase, he asked himself:"how many different ways of strides are there for him to get the top of the hill?". Of course, because of his height, he could only stride a limited range of steps. He was smart so much so that he got the answer quickly. Do you know how he did it?

            Input Specification

            The input consists of several test cases, each of which occupies a line containing M(1<=M<=40) and N(1<=N<=10), where M indicates the number of the steps of the staircase and N indicates the maximal number of steps the bunny can stride once.

            Output Specification

            Each test case should correspond to a line in the output. Your program should print an integer which is the answer.

            Sample Input

            4 2
            5 4

            Sample Output

            5
            15


            題意是一只兔子要到距離為M(單位為1)的地方,它每步最多走N,問有多少種方法。輸入M  N 輸出r[m][n];


            解析:設為r[i][j],表示距離總共i且每次最多走j的方法數(可以沒有走出那大小為j的那步,只是允許走那步而已)。

            根據最后那一步可能走的長度,r[i-2][j]表示最后那步距離為2.r[i-j][j]表示最后那步距離為j.
            建立遞推關系r[i][j]=r[i-1][j]+r[i-2][j]+r[i-3][j]+r[i-j][j];
            //本人覺得這里特別難想,想到了也覺得無法建立遞推關系呀,j不是一直不變嗎?
            神奇的地方在于可以令r[0][j]=r[1][j]=1;當然還有r[i][1]=1
            -----------預處理----
            for(j=0;j<n;j++)

                   {

                          r[0][j]=1;

                          r[1][j]=1;

                   }

                   for(i=0;i<n;i++)

                          r[i][1]=1;


            ---dp----------
             for(i=2;i<m;i++)
                for(j=2;j<n;j++)
                {
                 if(i<j)
                    r[i][j]=r[i][i]; //這點非常重要
                 else 
                   for(k=1;k<=j;k++)
                    {
               r[i][j]+=r[i-k][j];
                    }
                }
            ------------
            r[1][1]=1
            r[2][1]=1
            r[2][2]=r[2][1]+r[2][2]=2;
            r[3][1]=1;
            r[3][2]=r[2][2]+r[1][2]=3;
            r[3][3]=r[0][3]+r[1][3]+r[2][3]=4;

            posted on 2009-07-20 17:19 luis 閱讀(545) 評論(0)  編輯 收藏 引用 所屬分類: 動態規劃
            <2012年11月>
            28293031123
            45678910
            11121314151617
            18192021222324
            2526272829301
            2345678

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            友情鏈接

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久久久国产精品嫩草影院| 亚洲综合精品香蕉久久网97 | 亚洲女久久久噜噜噜熟女| 亚洲精品综合久久| 人妻无码αv中文字幕久久琪琪布| 久久精品九九亚洲精品| 99久久国产综合精品五月天喷水 | 精品无码久久久久久午夜| 久久99中文字幕久久| 开心久久婷婷综合中文字幕| 久久精品国产男包| 国产午夜福利精品久久| 午夜视频久久久久一区| 国产精品九九九久久九九| 武侠古典久久婷婷狼人伊人| 国产一级持黄大片99久久| 久久伊人五月天论坛| 久久精品国产69国产精品亚洲| 久久丫忘忧草产品| 国产午夜精品久久久久九九电影| 亚洲精品无码久久千人斩| 99久久精品免费看国产| 久久水蜜桃亚洲av无码精品麻豆 | 国产精品九九久久精品女同亚洲欧美日韩综合区 | 69国产成人综合久久精品| 伊人久久一区二区三区无码| 国内精品久久久久国产盗摄| 精品无码久久久久久尤物| 日本五月天婷久久网站| 久久精品三级视频| 色综合久久久久网| 91精品国产色综久久| 精品国产一区二区三区久久| 久久精品亚洲中文字幕无码麻豆| 一本久久免费视频| 中文字幕久久亚洲一区| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 日韩精品久久久久久久电影| 久久精品中文字幕第23页| 色噜噜狠狠先锋影音久久| 精品久久久久久|