蓝桥杯练习-简单2

程序猿圈子里正在流行一种很新的简写方法:对于一个字符串,只保留首尾字符,将首尾字符之间的所有字符用这部分的长度代替。例如internation-alization 简写成i18n,Kubernetes (注意连字符不是字符电的一部分)简写成 K8s, Langiao 简写成 L5o 等
在本题中,我们规定长度大于等于K 的字符串都可以采用这种简写方法(长度小于K 的字符串不配使用这种简写。
给定一个字符串 S 和两个字符 c1和c2,请你计算 S 有多少个以从c1 开头 c2结尾的子可以采用这种简写?

暴力法

cpp 复制代码
#include <iostream>
using namespace std;
#define INF 0x3f3f3f3f

int clean(string s, char c1, char c2)
{
	int k;
	cin >> k;
	int count = 0;
	if (s.length() < k)return 0;               //若字符串小于直接返回0
	for (int i = 0; i < s.length(); i++)
	{
		 if(s[i] != c1)continue;                 //找到第一个c1开头的字符串
		for (int j = i; j < s.length(); j++)
		{
			if (s[j] == s[i]&&(j-i+1)>=k)count++;
		}
	}
	return count;
}
signed main()
{
	ios::sync_with_stdio;
	cin.tie(0);
	cout.tie(0);
	string s;
	char c1, c2;
	int n = 1;
	cin >> s;
	cin >> c1 >> c2;
	while (n--)
		cout << clean(s,c1,c2);

	
}

二分法

cpp 复制代码
#include <iostream>
using namespace std;
#define INF 0x3f3f3f3f
#include <vector>

int clean(string s, char c1, char c2)
{
	int k;
	cin >> k;
	int count = 0;
	if (s.length() < k)return 0;               //若字符串小于直接返回0
	vector<int>arr;
	for (int i = 0; i < s.size(); i++)
	{
		if (s[i] == c1)
			arr.push_back(i);
		if (s[i] == c2) 
		{
			if (!arr.size() || (i - k + 1) < 0) //没有一个首字符了,或者第一个尾字符的位置不满足k
				continue;
			if (arr[0] > (i - k + 1))continue;  //判断一种特殊情况所有的都在右边
			int l = 0, r = arr.size();
			while (l < r)
			{
				int mid = (l + r + 1) >> 1;
				if (arr[mid] > i - k + 1)
					r = mid - 1;
				else
					l = mid;
			}
			         
			   count += l;

		}
	}
	return count;
}
signed main()
{
	ios::sync_with_stdio;
	cin.tie(0);
	cout.tie(0);
	string s;
	char c1, c2;
	int n = 1;
	cin >> s;
	cin >> c1 >> c2;
	while (n--)
		cout << clean(s,c1,c2);

	
}
相关推荐
第二只羽毛1 分钟前
C++ 高并发内存池4
java·大数据·linux·c++·算法
散峰而望4 分钟前
【数据结构】并查集从入门到精通:基础实现、路径压缩、扩展域、带权,一网打尽
数据结构·c++·算法·github·剪枝·推荐算法
羚羊角uou10 分钟前
【Linux网络】select详解
linux·服务器·开发语言·网络·c++
C++ 老炮儿的技术栈10 分钟前
c++ this 指针的用途
c语言·开发语言·c++·windows·qt·github
会编程的土豆13 分钟前
【leetcode hot 100】依旧二叉树
算法·leetcode·职场和发展
风舞雪凌月14 分钟前
【趣谈】移动系统和桌面系统编程语言思考
java·c语言·c++·python·学习·objective-c·swift
阿i索15 分钟前
【蓝桥杯备赛Day5】排序
笔记·蓝桥杯·排序算法
Ricky_Theseus17 分钟前
C++全局变量、局部变量、静态全局变量、静态局部变量的区别
开发语言·c++
小此方18 分钟前
Re:从零开始的 C++ STL篇(十)map/set使用精讲:常见问题与典型用法(上)
开发语言·数据结构·c++·算法·stl
吴梓穆23 分钟前
UE5 c++ 模板函数
java·c++·ue5