蓝桥杯 字串简写(题目分析+C++完整代码)

字串简写

题目来源

蓝桥杯 2023 省赛

原题链接

蓝桥杯 字串简写

问题描述

程序猿圈子里正在流行一种很新的简写方法:对于一个字符串,只保留首尾字符 ,将首尾字符之间的所有字符用这部分的长度代替。例如 internation-alization 简写成 i18n,Kubernetes (注意连字符不是字符串的一部分)简写成 K8s, Lanqiao 简写成 L5o 等。

在本题中,我们规定长度大于等于 K 的字符串都可以采用这种简写方法(长度小于 K 的字符串不配使用这种简写)。

给定一个字符串 S和两个字符 c1和 c 2 ,请你计算 S 有多少个以 c1开头 c 2结尾的子串可以采用这种简写?

输入格式

第一行包含一个整数 K。

第二行包含一个字符串 S 和两个字符 c 1 和 c 2。

输出格式

一个整数代表答案。

样例输入

复制代码
4
abababdb a b
copy

样例输出

复制代码
6
copy

完整代码

暴力算法

通过率70%

cpp 复制代码
#include <iostream>
#include <cstring>
using namespace std;
int n;  //要求字符串长度大于n
string s;  //字符串
char a,b;  //起始、终止字符
int main()
{
  cin>>n;
  cin>>s>>a>>b;
  int res=0;
  //遍历字符串
  for(int i=0;i<=s.size()-n;i++){
    //若找到与起始字符a相同的字符
    if(s[i]==a){
      int j=i+n-1;  //长度大于n
      //遍历剩余字符串
      while(j<s.size()){
        if(s[j]==b) res++;
        j++;
      }
    }
  }
  cout<<res<<endl;
  return 0;
}

优化

通过率100%

cpp 复制代码
#include <iostream>
#include <cstring>
using namespace std;
const int N=5e5+10;
int n;  //要求字符串长度大于n
char a,b;  //起始、终止字符
string s;  //字符串
int sumb[N];  //记录从当前位置开始以后终止字符串的个数
int main()
{
  cin>>n>>s>>a>>b;
  long long res=0;
  int last=0;  //记录前一个终止字符记录的个数
  //逆序遍历
  for(int i=s.size()-1;i>=0;i--){
    if(s[i]==b){
      sumb[i]=last+1;  //从当前位置i开始往后的终止字符b的个数=后一个出现的b记录的个数sumb[i]+当前的一个b
      last=sumb[i];
    }
  }
  for(int i=0;i<=s.size()-n;i++){
    if(s[i]==a){
      int j=i+n-1;
      while(j!=s.size()){
        if(sumb[j]!=0){
          res+=sumb[j];
          break;
        }
        else j++;
      }
    }
  }
  cout<<res<<endl;
  return 0;
}
相关推荐
mochensage38 分钟前
CSP信奥赛C++常用系统函数汇总
c++·信奥
mochensage40 分钟前
C++信息学竞赛中常用函数的一般用法
java·c++·算法
fpcc43 分钟前
跟我学c++中级篇——多线程中的文件处理
c++
理智的灰太狼1 小时前
题目 3241: 蓝桥杯2024年第十五届省赛真题-挖矿
职场和发展·蓝桥杯
GUIQU.1 小时前
【每日一题 | 2025年6.2 ~ 6.8】第16届蓝桥杯部分偏简单题
算法·蓝桥杯·每日一题
5:002 小时前
云备份项目
linux·开发语言·c++
乄夜2 小时前
嵌入式面试高频(5)!!!C++语言(嵌入式八股文,嵌入式面经)
c语言·c++·单片机·嵌入式硬件·物联网·面试·职场和发展
YYDS3142 小时前
C++动态规划-01背包
开发语言·c++·动态规划
wydaicls3 小时前
十一.C++ 类 -- 面向对象思想
开发语言·c++
姜君竹4 小时前
QT的工程文件.pro文件
开发语言·c++·qt·系统架构