--- 这里是 cjiaw 的小窝(●'◡'●) ---

正在玩命加载中......

CF_2069_C. Beautiful Sequence

题目链接:Problem - C - Codeforces


题目大意:

给定一个只包含{1,2,3}且长度为 n 的 数组a,

问:有多少个序列以'1'开始,'3'结尾长度至少为 的子串,  对答案取 mod=998244353


DP:

用DP求子串数方法,

f[i]表示:以第 i 个字符结尾的最大子串数

  f[i] = f[i-1] + f[i-1] + 1

  f[i] =  ↑第 i - 1个字符结尾的最大子串数  + 在第 i - 1个最大子串数的基础上加上第 i 个字符 + 只选第 i 个字符


代码:

#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<vector>
#include<queue>
#include<deque>
#include<stack>
#include<set>
#include<map>
#include<unordered_set>
#include<unordered_map>
#include<bitset>
#include<tuple>
#define inf 72340172838076673
#define int long long
#define endl '\n'
#define F first
#define S second
#define  mst(a,x) memset(a,x,sizeof (a))
using namespace std;
typedef pair<int, int> pii;

const int N = 200086, mod = 998244353;

int n, m;
int a[N];
int f[N];

void solve() {

    cin >> n;
    int c1 = 0, res = 0;
    for (int i = 1; i <= n; i++) {
        cin >> a[i];
        f[i] = f[i - 1] % mod;
        if (a[i] == 1) c1++;// 记录1的数量
        else if (a[i] == 2) f[i] += f[i - 1] + c1;//不选这个数的子串+选这个数的子串+只选这个数和前面的1
        else res = (res + f[i]) % mod;//记录答案
    }
    
    cout << res << endl; 
}

signed main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr), cout.tie(nullptr);
    
    int T = 1;
    cin >> T;
    while (T--) solve();
    
    return 0;
}

 

posted @ 2025-10-13 10:56  cjiaw  阅读(5)  评论(0)    收藏  举报