C双指针滑动窗口算法

这也许是双指针技巧的最⾼境界了,如果掌握了此算法,可以解决⼀⼤类⼦字符串匹配的问题

原理

1、我们在字符串 S 中使⽤双指针中的左右指针技巧,初始化 left = right = 0,把索引闭区间 [left, right] 称为⼀个「窗⼝」。

2、我们先不断地增加 right 指针扩⼤窗⼝ [left, right],直到窗⼝中的字符串 符合要求(包含了 T 中的所有字符)。

3、此时,我们停⽌增加 right,转⽽不断增加 left 指针缩⼩窗⼝ [left, right],直到窗⼝中的字符串不再符合要求(不包含 T 中的所有字符了)。 同时,每次增加 left,我们都要更新⼀轮结果。

4、重复第 2 和第 3 步,直到 right 到达字符串 S 的尽头。

代码
cpp 复制代码
#include <stdio.h>

const char* matchString(const char* content, const char* sub) {
	// 数据初始化
	size_t size = strlen(content);
	size_t sub_size = strlen(sub);
	int flag[256] = {0};		// 字符数统计
	
	// 搜索区间
	const char* begin = content;
	const char* end = content + size;
	
	// 双指针动态滑动窗口
	const char* _left = begin;
	const char* right = begin;
	
	// 滑动匹配
	for(;right < end; ++right) {
		++flag[*right];	// 窗口内字符数统计
		
		// 缩小窗口,寻找可行解
		int i = 0;
		for(; i < sub_size;) {
			if(right - _left < sub_size)
				break;	// 窗口失效
			if(!flag[*(sub + i)])
				break; // 窗口失效
			if(*(_left + i) != *(sub + i)) {
				--flag[*(_left + i)]; // 窗口内字符数更新
				++_left;
				i= 0;
				continue;	// 缩小窗口,重新匹配
			}
			++i;
		}
		
		if(i == sub_size)
			return _left;  // 查找成功
	}
	return end;	// 查找失败
}
	
int main () {
	printf("%s\n", matchString("abccbaaabcbaabcacbacb", "acb"));
	return 0;
}
输出
复制代码
acbacb
问题

找到字符串中所有字⺟异位词?

⽆重复字符的最⻓⼦串?


创作不易,小小的支持一下吧!

相关推荐
AuroraWanderll3 小时前
C++类和对象--访问限定符与封装-类的实例化与对象模型-this指针(二)
c语言·开发语言·数据结构·c++·算法
white-persist3 小时前
网络空间安全核心领域技术架构深度解析
c语言·开发语言·网络·python·安全·网络安全·架构
月明长歌3 小时前
【码道初阶】LeetCode 622:设计循环队列:警惕 Rear() 方法中的“幽灵数据”陷阱
java·算法·leetcode·职场和发展
秦苒&3 小时前
【C语言指针三】一维数组传参的本质、冒泡排序、二级指针、指针数组、指针数组模拟二维数组、字符指针变量
c语言·开发语言
Dylan的码园3 小时前
链表与LinkedList
java·数据结构·链表
走错路的程序员3 小时前
C语言单片机与C#上位机之间传递大量参数比较好的实践方案
c语言·单片机·c#
mit6.8243 小时前
博弈-翻转|hash<string>|smid
算法
代码游侠3 小时前
复习——Linux 系统编程
linux·运维·c语言·学习·算法
Han.miracle3 小时前
优选算法-005 有效三角形的个数(medium)
数据结构·算法·有效的三角形个数
yuuki2332333 小时前
【C++】类和对象下
数据结构·c++·算法