蓝桥杯 字串简写(题目分析+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;
}
相关推荐
FL16238631296 分钟前
[C++]使用纯opencv部署yolov12目标检测onnx模型
c++·opencv·yolo
JenKinJia13 分钟前
Windows10配置C++版本的Kafka,并进行发布和订阅测试
开发语言·c++
互联网杂货铺27 分钟前
软件测试之压力测试
自动化测试·软件测试·测试工具·jmeter·职场和发展·测试用例·压力测试
wen__xvn1 小时前
每日一题洛谷P1914 小书童——凯撒密码c++
数据结构·c++·算法
云中飞鸿1 小时前
MFC中CString的Format、与XML中的XML_SETTEXT格式化注意
xml·c++·mfc
小小小白的编程日记2 小时前
List的基本功能(1)
数据结构·c++·算法·stl·list
努力可抵万难3 小时前
C++11新特性
开发语言·c++
ox00803 小时前
C++ 设计模式-策略模式
c++·设计模式·策略模式
egoist20233 小时前
【C++指南】一文总结C++类和对象【上】
开发语言·c++·类和对象·内存对齐·热榜·this指针·c++ 11
月上柳梢头&3 小时前
[C++ ]使用std::string作为函数参数时的注意事项
开发语言·c++·算法