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

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

算法分析:
    
    通過對串的某個性質來進行歸納,從而用動態規劃方法解決計數問題。
    類似的題有男人八題第一題,2010福州regional D題。
    dp[i,B/W]代表前i個,以B/W結尾的個數。
    dp[i,B]不必多說了,主要是dp[i,W]
    這里可以用來歸納的性質是:末尾一共有多少個連續的W。
    當末尾W的個數小于k的時候,答案等于dp[j,B] + ... dp[i-1,B], 其中j是i左邊的第一個為B的位置。
    當大于k的時候,除了包含上面的答案以外,對于超出的部分,是含有k個'B'的方案數總和。
    至于如何求含有k個'B'的方案數總和,這里就不講了,幾乎一模一樣。
#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>
            激情欧美日韩一区| 欧美福利影院| 久久精品1区| 午夜在线播放视频欧美| 一区二区欧美在线| 亚洲一区二区三区乱码aⅴ| 一区二区不卡在线视频 午夜欧美不卡在| 激情久久影院| 亚洲日本欧美| 亚洲一区二区三区中文字幕| 亚洲视频视频在线| 午夜精品网站| 好吊一区二区三区| 亚洲高清精品中出| 亚洲一区二区三区精品动漫| 国产精品高潮呻吟| 欧美日韩国产精品| 欧美日韩精品久久久| 欧美激情视频在线播放| 午夜日韩视频| 亚洲国产二区| 欧美激情导航| 亚洲国产女人aaa毛片在线| 美女主播一区| 亚洲人成在线观看一区二区| 亚洲美女免费视频| 亚洲男人第一网站| 久久久久久日产精品| 亚洲一区二区三区精品在线观看| 久久精品国产99国产精品| 久久久久久一区二区| 老司机精品视频网站| 欧美国产一区二区三区激情无套| 欧美精品久久久久久久久久| 国产精品99一区| 国产精品制服诱惑| 精品91久久久久| 亚洲狼人综合| 欧美一区二区在线看| 久久伊人一区二区| aa国产精品| 久久久久国产精品人| 欧美黑人国产人伦爽爽爽| 国产精品美女在线| 亚洲高清在线播放| 午夜一区二区三视频在线观看 | 最新成人av网站| 亚洲深夜福利视频| 欧美在线观看一区| 亚洲国产成人在线| 欧美在线看片| 欧美日韩一区在线| 在线免费观看日韩欧美| 一区二区三区精品在线 | 亚洲第一区色| 国产精品99久久99久久久二8 | 亚洲欧洲免费视频| 日韩亚洲国产欧美| 欧美伊人久久久久久久久影院| 亚洲美女区一区| 亚洲精品一区二区在线观看| 午夜一级久久| 午夜电影亚洲| 亚洲欧美日韩在线播放| 免费日韩av片| 亚洲欧美在线aaa| 欧美日韩小视频| 国产精品都在这里| 日韩亚洲一区二区| 欧美高清在线播放| 欧美制服丝袜| 国产精品永久免费| 亚洲高清在线观看| 亚洲永久网站| 亚洲在线一区| 欧美涩涩视频| 亚洲午夜羞羞片| 亚洲精品一品区二品区三品区| 久热re这里精品视频在线6| 国产一区二区三区四区| 欧美在线看片| 欧美专区日韩视频| 极品少妇一区二区| 免费一级欧美片在线观看| 久久久国产91| 伊人久久噜噜噜躁狠狠躁| 欧美中文在线视频| 亚洲欧美日韩一区二区三区在线观看 | 欧美日韩成人免费| 亚洲精品少妇| 亚洲国产一区在线观看| 欧美国产日韩在线| 亚洲一级二级在线| 亚洲欧美电影在线观看| 国产精品入口麻豆原神| 久久国产精品久久国产精品| 午夜亚洲视频| 亚洲福利视频免费观看| 久久精品一本| 亚洲一区国产精品| 欧美日韩久久| 在线中文字幕一区| 久久天堂av综合合色| 亚洲欧洲日本在线| 另类图片国产| 国产一区二区三区日韩| 欧美一区二区三区四区高清 | 亚洲一区二区三区在线| 国产亚洲欧美一区在线观看| 巨胸喷奶水www久久久免费动漫| 久久亚洲图片| 亚洲一区二区三区激情| 欧美在线观看你懂的| 国产在线精品一区二区夜色| 欧美成人亚洲成人日韩成人| 欧美日韩精品综合在线| 欧美日韩精品二区| 亚洲欧美国产77777| 日韩亚洲欧美成人| 国产综合色精品一区二区三区| 蜜臀av在线播放一区二区三区| 欧美大成色www永久网站婷| 亚洲天堂av在线免费观看| 欧美在线观看视频| 日韩午夜三级在线| 欧美影院成人| 亚洲社区在线观看| 久久免费视频这里只有精品| 亚洲视频精选在线| 狼狼综合久久久久综合网| 久久久久高清| 国产精品看片你懂得| 亚洲国产精品第一区二区三区| 国产乱理伦片在线观看夜一区| 亚洲国产一区二区三区高清| 韩国一区电影| 午夜精品在线| 亚洲永久精品大片| 欧美精品在线观看| 欧美成人高清| 国产综合av| 亚洲一区综合| 狠狠色综合色综合网络| 99在线观看免费视频精品观看| 久久精品国产在热久久| 性色av一区二区三区在线观看| 欧美精品一区二区三区蜜桃| 免费欧美日韩国产三级电影| 国产偷国产偷精品高清尤物| 99视频一区| 亚洲一级黄色| 欧美精品观看| 亚洲午夜一区二区| 亚洲免费影视第一页| 欧美精品亚洲| 亚洲精品中文在线| 亚洲视频每日更新| 欧美午夜视频网站| 一本色道久久综合狠狠躁篇怎么玩| 亚洲国产日韩欧美一区二区三区| 久久国产欧美| 美女精品自拍一二三四| 黑人巨大精品欧美黑白配亚洲| 午夜精品久久久久久久蜜桃app| 亚洲伊人网站| 欧美激情第二页| 精品动漫一区| 欧美日韩a区| 一区二区三区高清不卡| 亚洲欧美国产va在线影院| 国产精品每日更新| 亚洲综合电影| 老牛嫩草一区二区三区日本| 经典三级久久| 欧美极品一区| 亚洲天堂免费观看| 久久精品一区中文字幕| 红桃视频国产精品| 欧美国产日产韩国视频| 亚洲精品视频免费| 亚洲一区图片| 国产一区二区三区电影在线观看| 欧美伊人精品成人久久综合97 | 欧美日韩影院| 中文欧美字幕免费| 欧美一级视频精品观看| 国产一区二区欧美| 欧美激情bt| 香蕉尹人综合在线观看| 久久综合九色综合欧美就去吻| 亚洲高清一二三区| 欧美日韩综合不卡| 久久精品中文字幕免费mv| 欧美激情乱人伦| 欧美一区二区女人| 日韩午夜激情| 欧美日韩亚洲不卡| 欧美在线播放一区| 99这里有精品| 欧美福利视频|