• <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>
            算法學(xué)社
            記錄難忘的征途
            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 西月弦 閱讀(333) 評論(0)  編輯 收藏 引用

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


            久久青青草视频| 久久久久一区二区三区| 无码国内精品久久综合88| 久久人人妻人人爽人人爽| 国产99久久久久久免费看 | 久久精品水蜜桃av综合天堂| 青青青青久久精品国产| 影音先锋女人AV鲁色资源网久久| 热99re久久国超精品首页| 囯产精品久久久久久久久蜜桃| 欧美精品一区二区精品久久| 中文字幕久久精品无码| 亚洲v国产v天堂a无码久久| 色综合久久久久网| 久久精品亚洲日本波多野结衣| 一级做a爰片久久毛片毛片| 99久久精品免费观看国产| 国产精品久久永久免费| 久久久久久国产精品免费无码| 蜜桃麻豆WWW久久囤产精品| 久久露脸国产精品| 久久国产乱子伦精品免费午夜| 国产亚洲欧美成人久久片| 精品久久久久久亚洲精品 | 99久久精品日本一区二区免费| 2021国产精品午夜久久| 久久久高清免费视频| 久久久久久久久66精品片| 亚洲日韩欧美一区久久久久我| 无码任你躁久久久久久| 精品国产乱码久久久久软件| 欧美麻豆久久久久久中文| 久久综合九色欧美综合狠狠| 思思久久99热免费精品6| 亚洲欧美一区二区三区久久| 欧美成人免费观看久久| 久久久亚洲欧洲日产国码是AV| 97久久婷婷五月综合色d啪蜜芽| 久久精品国产99国产精品导航| 久久亚洲精品国产精品| 97超级碰碰碰碰久久久久|