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

算法學社
記錄難忘的征途
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>
            欧美深夜影院| 久久在线视频在线| 欧美极品aⅴ影院| 欧美在线综合| 午夜日韩视频| 久久aⅴ乱码一区二区三区| 亚洲无线一线二线三线区别av| 亚洲日本在线观看| 国产精品久久久久av免费| 亚洲视频在线观看免费| 国产精品99久久不卡二区| 亚洲自拍偷拍色片视频| 欧美怡红院视频一区二区三区| 欧美专区第一页| 老色鬼精品视频在线观看播放| 91久久黄色| 亚洲黄色成人网| 正在播放日韩| 欧美在现视频| 欧美电影免费观看高清| 洋洋av久久久久久久一区| 香蕉成人久久| 欧美国产日韩一区二区在线观看| 亚洲国产精品久久人人爱蜜臀| 亚洲人成高清| 欧美影院在线播放| 麻豆精品视频| 国产精品呻吟| 亚洲欧洲一区二区三区久久| 亚洲图中文字幕| 乱中年女人伦av一区二区| 亚洲精品精选| 欧美一区二区三区免费观看视频 | 久久精品一区| 欧美日韩成人激情| 国产一区在线视频| 中文国产成人精品| 欧美成人激情视频| 午夜精品偷拍| 欧美日韩在线另类| 久久福利电影| 欧美激情1区| 黄色亚洲在线| 小嫩嫩精品导航| 亚洲精品一线二线三线无人区| 欧美一区在线看| 久久久噜噜噜久久人人看| 亚洲午夜一区二区| 久久这里只精品最新地址| 亚洲视频碰碰| 欧美视频在线视频| 亚洲精品视频一区| 欧美成人免费大片| 欧美影院视频| 久久综合影视| 亚洲资源av| 国产精品久久久久久亚洲调教 | 136国产福利精品导航| 亚洲欧美日韩在线一区| 亚洲欧洲一区二区在线播放| 老司机精品视频网站| 国内精品视频在线观看| 欧美一站二站| 亚洲字幕在线观看| 国产精品资源| 欧美视频免费在线| 日韩午夜黄色| 亚洲精品国产精品久久清纯直播 | 久久综合九色| 欧美在线啊v| 国产尤物精品| 久久人人爽人人爽| 久久久久亚洲综合| 亚洲区免费影片| 亚洲精品综合精品自拍| 欧美精品一区二区三区蜜臀| 一级成人国产| 亚洲午夜一区二区三区| 国产精品美女久久久浪潮软件| 午夜免费久久久久| 欧美一区二区三区视频在线观看 | 欧美亚洲一区二区在线| 国产一区二区三区四区在线观看 | 黄色亚洲免费| 亚洲国产精品一区二区久| 欧美裸体一区二区三区| 亚洲性视频h| 欧美在线免费观看视频| **欧美日韩vr在线| 亚洲精品久久| 国产一区二区你懂的| 欧美高清hd18日本| 欧美视频在线播放| 久久综合电影| 国产综合自拍| 亚洲裸体俱乐部裸体舞表演av| 欧美日产国产成人免费图片| 亚洲欧美视频一区| 久久婷婷av| 一区二区三区久久精品| 欧美亚洲视频一区二区| 99视频超级精品| 欧美在线一二三| 一区二区三区欧美亚洲| 久久精品卡一| 午夜视频一区二区| 欧美激情久久久| 久久久免费观看视频| 欧美深夜影院| 亚洲伦理在线| 亚洲日本成人女熟在线观看| 午夜精品久久久久影视| 一二三四社区欧美黄| 久久亚洲欧美国产精品乐播| 欧美一区午夜精品| 欧美亚州韩日在线看免费版国语版| 鲁大师影院一区二区三区| 国产欧美精品日韩精品| 亚洲美洲欧洲综合国产一区| 激情91久久| 欧美一区二区免费| 亚洲欧美国产精品专区久久| 欧美激情精品久久久久久蜜臀| 久久影音先锋| 国产一区二区三区无遮挡| 亚洲自拍偷拍福利| 亚洲欧美日韩精品久久| 欧美日韩国产首页在线观看| 欧美激情片在线观看| 在线观看中文字幕不卡| 久久国产免费看| 另类国产ts人妖高潮视频| 国产手机视频精品| 性做久久久久久| 欧美在线视频一区二区三区| 国产精品久久久久久久久久久久久| 亚洲精品久久久一区二区三区| 亚洲国产精品传媒在线观看| 久久亚洲一区二区| 女仆av观看一区| 激情偷拍久久| 久久性色av| 欧美高清在线视频观看不卡| 亚洲高清色综合| 狼狼综合久久久久综合网| 欧美激情第二页| 亚洲精品日韩精品| 欧美成人在线免费观看| 亚洲欧洲视频在线| 亚洲一区二区在线视频| 国产精品免费视频xxxx | 久久久久久久高潮| 久久色中文字幕| 亚洲高清资源| 欧美日韩国产欧美日美国产精品| 亚洲精品在线观看免费| 亚洲自拍电影| 国产亚洲精品成人av久久ww| 久久国产精品一区二区三区| 欧美h视频在线| 亚洲乱码精品一二三四区日韩在线 | 老司机一区二区三区| 亚洲成色999久久网站| 欧美二区视频| 国产精品99久久久久久有的能看| 欧美一二三视频| 好看的av在线不卡观看| 免费人成精品欧美精品| 99在线热播精品免费99热| 欧美一区二区精品在线| 黄色成人在线免费| 欧美日韩在线第一页| 欧美一区二区免费| 亚洲美女av电影| 久久久精品国产一区二区三区| 在线观看三级视频欧美| 欧美日产在线观看| 久久久久欧美精品| 中文网丁香综合网| 欧美多人爱爱视频网站| 亚洲欧美网站| 亚洲精品美女久久久久| 国产日韩欧美不卡| 欧美精品精品一区| 久久成人精品电影| 99在线精品视频| 欧美韩国日本一区| 久久九九有精品国产23| 亚洲一区二区三区在线| 禁久久精品乱码| 国产麻豆精品在线观看| 欧美精品一二三| 久久九九久精品国产免费直播| 在线视频欧美一区| 亚洲国产精品女人久久久| 久久久久久久久久久久久9999| 一本久久综合亚洲鲁鲁五月天| 黄色一区二区三区四区| 国产欧美精品日韩精品| 国产精品日韩欧美一区二区|