• <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代表 倒數第二個位置是n - 1 ,p = 2代表倒數第二個位置是 n, p = 0代表其他,q代表最后一個位置。

                然后轉移不難想。。。。

             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 西月弦 閱讀(327) 評論(0)  編輯 收藏 引用
            色播久久人人爽人人爽人人片AV| 久久99热只有频精品8| 色综合久久中文综合网| 狠狠精品久久久无码中文字幕| 性高湖久久久久久久久AAAAA| 午夜天堂精品久久久久| 91亚洲国产成人久久精品网址| 一本久久a久久精品综合香蕉| 国内精品久久久人妻中文字幕| 久久99精品久久久久久水蜜桃 | 亚洲国产成人久久一区WWW| 久久亚洲国产精品成人AV秋霞| 精品午夜久久福利大片| 久久国产AVJUST麻豆| 99久久国产综合精品五月天喷水| 久久天天躁狠狠躁夜夜躁2014| 99久久国产亚洲高清观看2024 | 色噜噜狠狠先锋影音久久| 人妻少妇精品久久| 久久er国产精品免费观看2| 亚洲中文字幕无码久久2020 | 国产成人精品免费久久久久| 蜜桃麻豆www久久国产精品| 久久免费线看线看| 国产产无码乱码精品久久鸭| 久久www免费人成看片| 欧美久久综合九色综合| 久久精品国产精品亚洲人人| 97超级碰碰碰碰久久久久| 99久久人妻无码精品系列蜜桃| 狠狠色综合网站久久久久久久高清| 久久无码国产| 久久久久国产成人精品亚洲午夜| 国产精品一久久香蕉产线看 | 久久久久亚洲av综合波多野结衣 | 久久久久99精品成人片牛牛影视| 久久91精品久久91综合| 狠狠狠色丁香婷婷综合久久五月 | 亚洲一区二区三区日本久久九| AV色综合久久天堂AV色综合在| 国产精品一区二区久久精品|