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

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

一、视频讲解

视频讲解
在这里插入图片描述

二、暴力代码


//暴力代码:
#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();
}

三、正解代码

//子串简写:二分
#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();
}

相关推荐

  1. 2019年第十届省赛-不同的

    2024-01-26 15:18:02       53 阅读

最近更新

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

    2024-01-26 15:18:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-26 15:18:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-26 15:18:02       82 阅读
  4. Python语言-面向对象

    2024-01-26 15:18:02       91 阅读

热门阅读

  1. C语言——转义字符

    2024-01-26 15:18:02       58 阅读
  2. DB OmitEmity漏洞介绍

    2024-01-26 15:18:02       52 阅读
  3. go-zero配置DB的redis缓存

    2024-01-26 15:18:02       59 阅读
  4. Codeforces Round 914 (Div. 2) | JorbanS

    2024-01-26 15:18:02       55 阅读
  5. Nginx_入门

    2024-01-26 15:18:02       54 阅读
  6. Nginx

    Nginx

    2024-01-26 15:18:02      49 阅读
  7. lvm详解

    2024-01-26 15:18:02       46 阅读
  8. 04-Seata修改通信端口

    2024-01-26 15:18:02       50 阅读
  9. 提效IntelliJ IDEA插件

    2024-01-26 15:18:02       47 阅读