• <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 - 141,comments - 220,trackbacks - 0

            題目描述:

               1...n的排列 p1 ... pn ,位置 i 是good,當且僅當 abs(pi - i) = 1。 問大小為N ,恰好有K個位置是good的排列是多少?

            算法分析:

               非常好的一道題,O(n^2) DP搞之。
               
               dp[n][k][p][q] 代表 大小為n,有k個good位置,p = 1代表 倒數(shù)第二個位置是n - 1 ,p = 2代表倒數(shù)第二個位置是 n, p = 0代表其他,q代表最后一個位置。

                然后轉(zhuǎn)移不難想。。。。

             1 #include<iostream>
             2 #include<cstdio>
             3 using namespace std;
             4 #define re(i,n) for(int i = 0; i < n; i++)
             5 typedef long long ll;
             6 const int N = 1005;
             7 const int mod = (int)1e9+7;
             8 ll dp[N][N][3][3];
             9 int main(){
            10     int n,k;
            11     cin >> n >> k;
            12     dp[1][0][0][1] = 1;
            13     dp[2][0][1][2] = 1;
            14     dp[2][2][2][1] = 1;
            15     for(int i = 3; i <= n; i++){
            16         for(int k = 0; k <= i; k++) {
            17             //  * 2
            18             re(p,2) re(q,3) dp[i][k][p][2] += dp[i-1][k][q][p+1];
            19             re(q,3) dp[i][k][0][2] += dp[i-1][k][q][0];
            20             // 2 1
            21             if(k >= 2) re(q,2) dp[i][k][2][1] += dp[i-1][k-2][q][2];
            22             // 2 0
            23             re(q,3) dp[i][k][2][0] += dp[i-1][k][q][1];
            24             if(k >= 1) re(q,3) dp[i][k][2][0] += dp[i-1][k-1][q][0];
            25             // 0 1
            26             dp[i][k][0][1]  += dp[i-1][k][2][1] + dp[i-1][k][2][0];
            27             if(k >= 1) dp[i][k][0][1] += dp[i-1][k-1][0][0] + dp[i-1][k-1][0][1] + dp[i-1][k-1][1][0];
            28             // 1 0
            29             re(q,2) dp[i][k][1][0] += dp[i-1][k+1][q][2] * (k + 1);
            30             if(i - 2 - k >= 0) re(q,2) dp[i][k][1][0] += dp[i-1][k][q][2] * (i - 2 - k);
            31             // 0 0 vs 2 1
            32             ll &ans = dp[i][k][0][0];
            33             if(k - 1 >= 0) ans += dp[i-1][k+1][2][1] * (k - 1) ;
            34                if(i - 1 - k >= 0) ans += dp[i-1][k][2][1] * (i - 1 - k);
            35 //            cout<<"vs 2 1: "<<i<<" "<<k<<" "<<ans<<endl;
            36             // 0 0 vs 2 0
            37             ans += dp[i-1][k + 1][2][0] * k;
            38             if( i - 2 - k >= 0) ans += dp[i-1][k][2][0] * (i - 2 - k);
            39 //            cout<<"vs 2 0: "<<i<<" "<<k<<" "<<ans<<endl;
            40             // 0 0 vs * 2
            41 //            re(q,2) ans += dp[i-1][k+1][q][2] * (k + 1);
            42 //            re(q,2) if(i - 2 - k >= 0)ans += dp[i-1][k][q][2] * (i - 2 - k);
            43             // 0 0 vs * 0
            44             re(q,2) ans += dp[i-1][k+1][q][0] * (k + 1);
            45             if(i - 3 - k >= 0) re(q,2) ans += dp[i-1][k][q][0] * (i - 3 - k);
            46 //            cout<<"vs * 0: "<<i<<" "<<k<<" "<<ans<<endl;
            47             // 0 0 vs 0 1
            48             ans += dp[i-1][k+1][0][1] * k;
            49             if(i - 2- k >= 0) ans += dp[i-1][k][0][1] * (i - 2 - k);
            50 //            cout<<"vs 0 1: "<<i<<" "<<k<<" "<<ans<<endl;
            51             re(p,3) re(q,3) dp[i][k][p][q] %= mod;
            52         }
            53     }
            54     ll ans = 0;
            55     re(q,3) re(p,3){
            56         ans += dp[n][k][p][q];
            57 //        cout<<p<<" "<<q<<" "<<dp[n][k][p][q]<<endl;
            58     }
            59 //    int a,b,c,d; while(cin >> a >> b >> c >> d) cout<<dp[a][b][c][d]<<endl;
            60     cout << ans % mod << endl;
            61 }
            62 
            posted on 2013-03-22 16:11 西月弦 閱讀(329) 評論(0)  編輯 收藏 引用

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


            久久这里只有精品18| 一本色综合网久久| 久久AV高清无码| 国产亚洲精久久久久久无码77777 国产亚洲精品久久久久秋霞 | 久久精品国产精品亚洲人人 | 伊人久久精品影院| 久久人人爽人人爽AV片| 亚洲午夜精品久久久久久app| 久久亚洲视频| 欧美日韩精品久久久久| 手机看片久久高清国产日韩 | 国产成人久久777777| 久久精品国产欧美日韩| 欧美久久亚洲精品| yy6080久久| 91久久精一区二区三区大全| 久久久青草青青亚洲国产免观| 91精品国产综合久久香蕉 | 久久久久久国产精品美女| 一本色道久久88综合日韩精品| 一本久久知道综合久久| 久久久久久午夜成人影院| 精品综合久久久久久97超人| 狠狠色婷婷综合天天久久丁香| 嫩草影院久久国产精品| 久久亚洲国产成人影院网站| 99久久夜色精品国产网站| 久久精品国产91久久综合麻豆自制| 国内精品久久久久久麻豆| 久久人妻无码中文字幕| 精品久久久久久| 久久午夜无码鲁丝片秋霞| 久久中文娱乐网| 国色天香久久久久久久小说| 99久久精品无码一区二区毛片| 国产成年无码久久久免费| 久久久久四虎国产精品| 热re99久久6国产精品免费| 久久精品国产99久久丝袜| 99久久99久久精品免费看蜜桃| 亚洲国产成人精品女人久久久|