蓝桥杯2023年第十四届省赛真题-子串简写(递推)

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

solution

注意首尾元素也可能相等,c语言网有相应的测试用例,不过蓝桥杯木得。

#include<iostream>
#include<string>
using namespace std;
const int maxn = 5e5 + 10;
int sum[maxn] = {0};
int main(){
    int k;
    long long ans = 0;
    string s;
    char l, r;
    cin >> k >> s >> l >> r;
    s = " " + s;
    for(int i = 1; i < s.size(); i++){
        sum[i] = sum[i - 1];//前缀和记录合法开头方案数
        if(s[i] == l) sum[i]++;
        if(s[i] == r && i >= k) ans += sum[i - (k - 1)];//递推,发现目标结尾,累计当前有的几种合法开头 
    }
    cout << ans;
    return 0;
}

相关推荐

  1. 2019-不同的

    2024-04-10 04:56:02       53 阅读
  2. 2023----棋盘

    2024-04-10 04:56:02       61 阅读
  3. 2023-阶乘求和

    2024-04-10 04:56:02       64 阅读
  4. 2023-飞机降落

    2024-04-10 04:56:02       53 阅读
  5. 2023-飞机降落

    2024-04-10 04:56:02       37 阅读
  6. C语言-2023-砍树

    2024-04-10 04:56:02       57 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-10 04:56:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-10 04:56:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-10 04:56:02       82 阅读
  4. Python语言-面向对象

    2024-04-10 04:56:02       91 阅读

热门阅读

  1. python中的shutil 压缩打包模块

    2024-04-10 04:56:02       27 阅读
  2. c++ 定义文件类

    2024-04-10 04:56:02       36 阅读
  3. C语言编译过程

    2024-04-10 04:56:02       32 阅读
  4. [C++/Linux] UDP编程

    2024-04-10 04:56:02       35 阅读
  5. 【LeetCode热题100】【二叉树】二叉树的层序遍历

    2024-04-10 04:56:02       42 阅读