青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

算法學(xué)社
記錄難忘的征途
posts - 141,comments - 220,trackbacks - 0
題目描述:
    有一個長度為n(n<1,000,000)的字符串A。有三種字符,'B','W','X'。現(xiàn)在讓你將所有的X要么變成B,要么變成W,構(gòu)造字符串,使得其存在a<=b<c<=d(b-a+1 == d-c+1 == k(k<=n)),其中 Aa...Ab = B Ac...Ad = W。求構(gòu)造方法,mod 1e9+7.

算法分析:
    
    通過對串的某個性質(zhì)來進(jìn)行歸納,從而用動態(tài)規(guī)劃方法解決計數(shù)問題。
    類似的題有男人八題第一題,2010福州regional D題。
    dp[i,B/W]代表前i個,以B/W結(jié)尾的個數(shù)。
    dp[i,B]不必多說了,主要是dp[i,W]
    這里可以用來歸納的性質(zhì)是:末尾一共有多少個連續(xù)的W。
    當(dāng)末尾W的個數(shù)小于k的時候,答案等于dp[j,B] + ... dp[i-1,B], 其中j是i左邊的第一個為B的位置。
    當(dāng)大于k的時候,除了包含上面的答案以外,對于超出的部分,是含有k個'B'的方案數(shù)總和。
    至于如何求含有k個'B'的方案數(shù)總和,這里就不講了,幾乎一模一樣。
#include<iostream>
#include<cstdio>
using namespace std;
typedef long long ll;
const int N = int(1e6)+10;
const int mod = int(1e9)+7;
char ch[N];
ll nearb[N],neara[N],sumb[N][2],haveb[N][2],all[N],dp[N][2],sum[N][2];
int main(){
    int n,k;
    #define havab haveb
    while(~scanf("%d%d",&n,&k)){
        scanf("%s",ch);
        all[0]=1;
        for(int i=1;i<=n;i++){
            char x = ch[i-1];
            if(x == 'B') nearb[i] = i, neara[i] = neara[i-1];
            else if(x == 'W') nearb[i] = nearb[i-1], neara[i] = i;
            else nearb[i] = nearb[i-1] , neara[i] = neara[i-1];
            if(x == 'X') all[i] = (all[i-1] <<1) % mod;
            else all[i] = all[i-1];
            int j= neara[i],p = i - k;
            if(p < j) p = j-1;
            if(p<0) p=0;
            if(x == 'W') {
                haveb[i][1] = 0;
                haveb[i][0] = (havab[i-1][0] + havab[i-1][1]) % mod; 
            }
            else {
                if(x == 'B') havab[i][0] = 0;
                else havab[i][0] = (havab[i-1][0] + havab[i-1][1]) % mod; 
                havab[i][1] = (sumb[i-1][0] - sumb[p][0] + mod) % mod; 
                if(i-j>=k) {
                    havab[i][1] += all[p];
                    havab[i][1] %= mod;
                }
            }
//            cout<<"i: "<<i<<" "<<haveb[i][0]<<" "<<haveb[i][1]<<endl;
            sumb[i][0] = (sumb[i-1][0] + haveb[i][0] ) % mod;
            sumb[i][1] = (sumb[i-1][1] + haveb[i][1] ) % mod;
            j = nearb[i];
            p = i - k;
            if(p < j) p = j-1;
            if(p<0) p=0;
            if(x == 'B') {
                dp[i][0] = 0;
                dp[i][1] = (dp[i-1][0] + dp[i-1][1]) % mod;
            }
            else {
                if(x == 'W') dp[i][1] = 0;
                else dp[i][1] = (dp[i-1][0] + dp[i-1][1]) % mod;
                dp[i][0] = (sum[i-1][1] - sum[p][1] + mod) % mod;
                if(i-j>=k) {
                    dp[i][0] += sumb[p][1] - sumb[j-1][1] + mod;
                    dp[i][0] %= mod;
                }
            }
//            cout<<j<<" "<<p<<endl;
//            cout<<"dp: "<<dp[i][0]<<" "<<dp[i][1]<<endl;
            sum[i][0] = (sum[i-1][0] + dp[i][0]) % mod;
            sum[i][1] = (sum[i-1][1] + dp[i][1]) % mod;
        }
        cout<<(dp[n][0] + dp[n][1]) % mod <<endl;
    }
}
posted on 2012-07-21 19:13 西月弦 閱讀(349) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品免费观看| 精品69视频一区二区三区| 一本久久a久久精品亚洲| 国产一区欧美日韩| 黑丝一区二区三区| 一区福利视频| 国产精品午夜视频| 国产精品久久久一本精品| 欧美手机在线| 国产手机视频精品| 在线观看一区视频| 亚洲欧美资源在线| 性久久久久久| 亚洲国产精品综合| 欧美激情日韩| 亚洲精品小视频在线观看| 久久精品国产99精品国产亚洲性色| 国产精品热久久久久夜色精品三区| 久久综合久久美利坚合众国| 亚洲小视频在线| 久久一综合视频| 欧美日韩精品在线观看| 国产一区二区中文| 在线午夜精品自拍| 欧美电影免费观看大全| 亚洲专区国产精品| 国产精品高清在线观看| 亚洲韩国精品一区| 欧美福利电影网| 久久成人精品一区二区三区| 欧美视频一区二区在线观看| 亚洲精品一区二区三区蜜桃久| 日韩一二在线观看| 欧美激情在线观看| 久久人91精品久久久久久不卡| 免费欧美视频| 亚洲丶国产丶欧美一区二区三区 | 亚洲精品欧美激情| 欧美在线影院| 亚洲在线播放| 国产精品日韩欧美大师| 亚洲欧美日韩精品综合在线观看| 亚洲午夜久久久| 亚洲国产欧美一区二区三区久久| 亚洲精品中文字幕女同| 久久夜精品va视频免费观看| 精品91在线| 久久综合久久综合久久综合| 美女精品在线| 亚洲精品乱码久久久久久蜜桃麻豆 | 日韩一级免费| 亚洲经典三级| 欧美视频在线观看 亚洲欧| 欧美一区国产一区| 嫩草影视亚洲| 亚洲美女啪啪| 久久精品国产v日韩v亚洲| 国产又爽又黄的激情精品视频 | 欧美成人国产| 亚洲视频在线观看视频| 亚洲人成欧美中文字幕| 国产亚洲在线| 99视频一区二区三区| 在线日本成人| 亚洲摸下面视频| 欧美黄网免费在线观看| 一区二区三区欧美日韩| 男人的天堂亚洲在线| 狠狠噜噜久久| 亚洲国产欧美在线人成| 国产精品久久久久久久久免费桃花| 国产真实久久| 午夜精品久久久久久久久| 亚洲视频一区二区| 欧美日韩第一区| 欧美激情一区二区三区蜜桃视频| 牛牛精品成人免费视频| 免费不卡视频| 亚洲最新视频在线| 国产精品免费视频观看| 亚洲一区二区三区免费观看| 亚洲欧美在线观看| 国产亚洲一区二区三区| 久久综合九色综合网站| 日韩午夜视频在线观看| 欧美综合国产| 亚洲国产高清一区二区三区| 午夜欧美大尺度福利影院在线看| 国产麻豆9l精品三级站| 久久国产精彩视频| 亚洲精选在线观看| 久久久久在线观看| 亚洲黑丝一区二区| 国产精品女主播| 久久视频这里只有精品| 亚洲精品系列| 免费不卡在线视频| 亚洲一区日韩| 亚洲国产精品国自产拍av秋霞 | 午夜精品一区二区三区电影天堂 | 久久精品国产免费看久久精品| 欧美国产激情| 午夜一区在线| 亚洲一区久久久| 日韩亚洲欧美在线观看| 亚洲视频一二区| 狠色狠色综合久久| 国产欧美日韩视频在线观看| 免费观看亚洲视频大全| 亚洲欧美在线观看| 一本色道综合亚洲| 91久久久久久| 一区二区三区.www| 亚洲激情婷婷| 一区二区三区视频在线| 日韩视频三区| 亚洲欧美在线一区| 国产一区二区成人| 欧美一区二区福利在线| 欧美专区福利在线| 久久er精品视频| 欧美成人亚洲| 国产精品久久久久一区二区三区| 欧美高清日韩| 国产精品亚洲欧美| 亚洲精品在线一区二区| 性久久久久久久久久久久| 噜噜噜91成人网| 亚洲一区二区毛片| 嫩模写真一区二区三区三州| 国产精品日韩在线| 亚洲精品一区二区三区蜜桃久 | 一区二区三区视频在线| 亚洲一级在线| 久热精品视频在线观看| 欧美日本免费一区二区三区| 国产午夜精品视频| 日韩亚洲欧美在线观看| 欧美国产免费| 国产一区二区精品久久91| 亚洲理伦在线| 蘑菇福利视频一区播放| 亚洲欧美自拍偷拍| 国产精品久久7| 亚洲欧美成aⅴ人在线观看| 亚洲国产精品久久久久久女王| 99re在线精品| 欧美激情精品久久久久久变态| 国产精品99免视看9| 一区二区电影免费观看| 亚洲精品免费看| 欧美日韩一区二区在线视频| 亚洲品质自拍| 一区二区国产精品| 国产精品视频不卡| 麻豆精品视频| 久久午夜电影| 一区二区免费看| 99国产精品私拍| 国产欧美亚洲视频| 你懂的国产精品| 欧美日韩蜜桃| 欧美一区二区在线观看| 久久综合久久久| 亚洲一区免费网站| 欧美亚洲免费电影| 99re6这里只有精品| 午夜久久久久| 最新国产精品拍自在线播放| 这里只有精品视频在线| 亚洲国产欧美不卡在线观看| 夜夜嗨av一区二区三区四季av | 欧美成人午夜激情在线| 亚洲欧美日韩一区二区在线| 欧美一区二区三区视频免费播放| 国产一区二区电影在线观看| 免费一级欧美片在线播放| 欧美天堂在线观看| 亚洲第一在线综合在线| 极品中文字幕一区| 亚洲欧美日韩一区二区三区在线观看 | 欧美暴力喷水在线| 久久在线播放| 久久黄色小说| 国产精品一区二区久激情瑜伽| 亚洲欧洲日韩在线| 欧美专区在线观看| 亚洲欧美国产高清va在线播| 欧美了一区在线观看| 免费美女久久99| 亚洲动漫精品| 免费人成精品欧美精品| 在线看国产一区| 欧美一区二视频| 国产精品亚洲欧美| 欧美日韩一区二区高清| 久久久综合网站| 欧美在线免费观看视频| 老司机一区二区三区| 亚洲免费观看高清在线观看|