亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

1276. Train

系統(tǒng) 2908 0

http://acm.timus.ru/problem.aspx?space=1&num=1276

用 ans[numaa][numab][numba][numbb][0] 表示用 numaa個(gè)AA ?numab個(gè)AB? numba個(gè)BA ?numbb個(gè)BB?? 以 A為結(jié)尾的種類數(shù)量

用 ans[numaa][numab][numba][numbb][1] 表示用 numaa個(gè)AA? numab個(gè)AB? numba個(gè)BA ?numbb個(gè)BB?? 以 B為結(jié)尾的種類數(shù)量

然后根據(jù)結(jié)尾是A還是B 進(jìn)行向后更新數(shù)量

代碼:

      #include<iostream>

#include<stdio.h>

#include<string.h>

#include<math.h>

#include<algorithm>

#include<vector>

#include<set>

#include<map>

#include<string>

#include<queue>

#include<stack>

#include <iomanip>

using namespace std;

#define LL long long

const int INF=0x3f3f3f3f;

const int N=45;

LL ans[20005][2];

int aa,ab,ba,bb;

int F(int i,int j,int l,int r)

{

    int x=r;

    x+=(l*bb);

    x+=(j*ba*bb);

    x+=(i*ab*ba*bb);

    return x;

}

int main()

{

    //freopen("data.in","r",stdin);

    int n,k;

    while(cin>>n>>k)

    {

        ab=0;aa=0;ba=0;bb=0;

        string stmp;

        int locomotive;

        cin>>stmp;

        if(stmp=="AA") locomotive=0;

        if(stmp=="AB") locomotive=1;

        if(stmp=="BA") locomotive=2;

        if(stmp=="BB") locomotive=3;

        for(int i=1;i<=n;++i)

        {

            cin>>stmp;

            if(stmp=="AA") ++aa;

            if(stmp=="AB") ++ab;

            if(stmp=="BA") ++ba;

            if(stmp=="BB") ++bb;

        }

        ++aa;++ab;++ba;++bb;

        memset(ans,0,sizeof(ans));

        if(locomotive==0||locomotive==2)

        ans[0][0]=1;

        else

        ans[0][1]=1;

        LL sum=0;

        for(int i=0;i<aa;++i)

        for(int j=0;j<ab;++j)

        for(int l=0;l<ba;++l)

        for(int r=0;r<bb;++r)

        if(i+j+l+r<=k)

        {

            int x=F(i,j,l,r);

            if(i+j+l+r==k)

            {

                if(locomotive==0||locomotive==1)

                sum+=ans[x][0];

                else

                sum+=ans[x][1];

            }

            if(ans[x][0]!=0)

            {

                if(i+1<aa)

                ans[F(i+1,j,l,r)][0]+=ans[x][0];

                if(j+1<ab)

                ans[F(i,j+1,l,r)][1]+=ans[x][0];

            }

            if(ans[x][1]!=0)

            {

                if(l+1<ba)

                ans[F(i,j,l+1,r)][0]+=ans[x][1];

                if(r+1<bb)

                ans[F(i,j,l,r+1)][1]+=ans[x][1];

            }

        }

        if(sum==0)

        cout<<"NO"<<endl;

        else

        {cout<<"YES"<<endl;cout<<sum<<endl;}

    }

    return 0;

}


    

1276. Train


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 福利视频影院 | 草逼网站| 午夜欧美 | 国产区成人综合色在线 | 国产福利视频网站 | 国内精品视频免费观看 | 国产激情久久久久影院小草 | 亚洲国产精品久久久久久 | 国产精品日韩欧美一区二区 | 免费一级毛片麻豆精品 | 国产精品久久久久久久久福利 | 一集毛片| 九九99久久精品影视 | 四虎影院免费在线播放 | 毛片一区 | 国产一区二区三区乱码网站 | 成人一级黄色片 | 久久中文网 | 亚洲国产精 | 久久综合九色综合97伊人麻豆 | 欧美激情精品久久久久 | 久久96国产精品 | 韩日性视频| 午夜久久免费视频 | 欧美成人精品一区二区三区 | 国产欧美精品一区二区三区–老狼 | 久久久久久久免费视频 | 人人乳乳香蕉大免费 | 免费香蕉依人在线视频久 | 久久网站免费观看 | 夜夜夜夜夜操 | 2020久久精品国产免费 | 国产视频二 | 97在线视频免费观看费观看 | 国产成人综合久久综合 | 久久久久久亚洲精品影院 | 国产精品a v 免费视频 | 日本一区二区三区欧美在线观看 | 日本不卡免费高清一级视频 | 成年女人18级毛片毛片 | 日韩高清性爽一级毛片免费 |