洛谷 CF894A QAQ

2019-08-16 08:02:02来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

洛谷 CF894A QAQ

目录

  • 题目
  • 思路
  • $Code$

题目

CF894A

思路

$\text{DP}$
一个数组$\text{QAQ[4][101]}$
$\text{QAQ[1][i]表示在i这个位置q的个数}$
$\text{QAQ[2][i]表示在i这个位置qa的个数}$
$\text{QAQ[3][i]表示在i这个位置能形成QAQ的个数}$
对于第$i$个位置的$Q$
可以组成$\text{QAQ[2][i]}$个$QAQ$
所以$\text{QAQ[3][i]+=QAQ[2][i]}$
对于第$i$个位置的$A$
可以组成$\text{QAQ[1][i]}$个$QA$
所以$\text{QAQ[2][i]+=QAQ[1][i]}$

$Code$

#include<iostream>
#include<cstring>
#include<string>
#include<cstdio>
#include<algorithm>
using namespace std;
string s;
int QAQ[4][101];
//QAQ[1][i]表示在i这个位置q的个数
//QAQ[2][i]表示在i这个位置qa的个数 
//QAQ[3][i]表示在这个位置能形成QAQ的个数 
inline int read(){
    int x=0;bool f=0;char c=getchar();
    while(c<'0'||c>'9'){if(c=='-')f=!f;c=getchar();}
    while(c>='0'&&c<='9'){x=x*10+c-'0';c=getchar();}
    return f?-x:x;
}

int main(){
    cin>>s;
    int ns=s.length();
    for(int i=0;i<ns;++i){
        if(i!=0){
            QAQ[1][i]=QAQ[1][i-1];
            QAQ[2][i]=QAQ[2][i-1];
            QAQ[3][i]=QAQ[3][i-1];
        }
        if(s[i]=='Q'){
            QAQ[1][i]++;
            QAQ[3][i]+=QAQ[2][i];
        }
        if(s[i]=='A'){
            QAQ[2][i]+=QAQ[1][i];
        }
    }
    cout<<QAQ[3][ns-1];
    return 0;
}

原文链接:https://www.cnblogs.com/poi-bolg-poi/p/11352470.html
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:C++ algorithm算法库

下一篇:Prime Time UVA - 10200(精度处理,素数判定)