[蓝桥杯]真题讲解:子串简写(暴力+二分)

[蓝桥杯]真题讲解:子串简写(暴力+二分)

一、视频讲解

视频讲解

二、暴力代码

cpp 复制代码
//暴力代码:
#include<bits/stdc++.h>
#define int long long
using namespace std;

void solve()
{
	int k; 
	string s;
	char c1, c2;
	cin >> k >> s >> c1 >> c2;
	int ans = 0;
	for(int i = 0; i < s.size(); i ++)
	{
		if(s[i] != c1)
			continue;
		for(int j = i + 1; j < s.size(); j ++)
		{
			int len = j - i + 1;
			if(len >= k && s[j] == c2)
				ans ++;
		}
	}
	cout << ans << endl;
}

signed main()
{
	ios::sync_with_stdio(0);
	cin.tie(0);
	int t = 1;
	// cin >> t;
	while(t--)
	solve();
}

三、正解代码

cpp 复制代码
//子串简写:二分
#include<bits/stdc++.h>
#define int long long
using namespace std;

void solve()
{
	int k;string s;
	char c1, c2;
	cin >> k >> s >> c1 >> c2;
	
	vector<int>pc1;//存储c1的位置

	int ans = 0;	
	for(int i = 0; i < s.size(); i ++)
	{
		if(s[i] == c1)
			pc1.push_back(i);
		
		if(s[i] == c2)
		{
		    if(i - k + 1 < 0 || !pc1.size())
		        continue;

		    int l = 0, r = (int)pc1.size() - 1;
		    while(l < r)
		    {
		    	int mid = l + r + 1 >> 1;
		    	if(pc1[mid] <= (i - k + 1))
		    		l = mid;
		    	else
		    		r = mid - 1;
		    }
		    
		    if(pc1[l] <= i - k + 1)
		    	ans += (l + 1);
		}
	}

	cout << ans << endl;
}

signed main()
{
	ios::sync_with_stdio(0);
	cin.tie(0);
	int t = 1;
	// cin >> t;
	while(t--)
	solve();
}
相关推荐
chengooooooo27 分钟前
代码随想录训练营第二十七天| 贪心理论基础 455.分发饼干 376. 摆动序列 53. 最大子序和
算法·leetcode·职场和发展
测试杂货铺2 小时前
如何用postman做接口自动化测试及完美的可视化报告?
自动化测试·软件测试·测试工具·职场和发展·jenkins·压力测试·postman
TT哇3 小时前
*【每日一题 基础题】 [蓝桥杯 2023 省 B] 飞机降落
算法·蓝桥杯
撞上电子3 小时前
蓝桥杯物联网开发板硬件组成
物联网·职场和发展·蓝桥杯
pzx_0013 小时前
【LeetCode】LCR 175.计算二叉树的深度
开发语言·c++·算法·leetcode·职场和发展
Aloha_up3 小时前
LeetCode hot100-89
算法·leetcode·职场和发展
测试老哥6 小时前
Jmeter测试脚本编写技巧
自动化测试·软件测试·功能测试·测试工具·jmeter·职场和发展·性能测试
逝灮7 小时前
【蓝桥杯——物联网设计与开发】拓展模块4 - 脉冲模块
stm32·单片机·嵌入式硬件·mcu·物联网·蓝桥杯·脉冲测量
Jamesvalley8 小时前
【工作流】工作顺序
职场和发展
ThisIsClark11 小时前
【后端面试总结】MySQL主从复制逻辑的技术介绍
mysql·面试·职场和发展