无重复的最长字串

📝个人主页:五敷有你

🔥系列专栏:算法分析与设计

⛺️稳中求进,晒太阳

问题

给定一个字符串,我们需要找到该字符串中的最长无重复子串的长度。

示例

让我们以一个具体的示例来说明这个问题:

输入: "abcabcbb"
输出: abc
解释: 最长无重复子串是 "abc",它的长度为 3。

解决思路

为了解决这个问题,我们可以使用滑动窗口和哈希表的方法。具体步骤如下:

  1. 我们使用两个指针来构建一个滑动窗口,表示当前无重复子串的范围。初始时,左指针和右指针都指向字符串的开头。
  2. 右指针向右移动,每次移动一个位置,直到找到一个重复字符或者到达字符串的末尾。
  3. 当遇到重复字符时,我们更新左指针的位置,将其移动到重复字符的下一个位置,确保滑动窗口内的字符都是不重复的。
  4. 在遍历过程中,我们使用哈希表来存储每个字符的最新位置,以便在发现重复字符时能够快速更新左指针的位置。
  5. 在每次移动右指针时,我们都更新最长无重复子串的长度。

代码实现

下面是用Java编写的实现代码:

java 复制代码
int lengthOfLongestSubstring(char* s) {

	if (s == NULL)
		return 0;

	int len = strlen(s);
	char* tmp = (char*)calloc(len, 1);
	int right = 0; // 当前字符串长度
	int left = 0; // 控制子串起始位置
	int maxlength = 0; // 记录最长长度

	for (int i = 0; i < len; i++)
	{
		char* p = strchr(tmp + left, s[i]);//这里需要注意的一点是字符必须先判断后复制

		tmp[right] = s[i];
		right++;

		if (p) // 如果该字符已存在,就跳到前面重复字符的下一个位置
		{
			left = p - tmp + 1;
		}

		int curlength = right - left; // 当前子串长度
		if (maxlength < curlength)// 找最长
		{
			maxlength = curlength;
		}
	}

	free(tmp);

	return maxlength;
}

运行结果

结论

通过使用滑动窗口和哈希表的方法,我们能够高效地解决寻找最长无重复子串的问题。这种方法的时间复杂度是 O(n),其中 n 是输入字符串的长度。我们的解决方案在处理大量数据时表现良好,能够在短时间内找到最长无重复子串,并返回其长度。

相关推荐
我真的不会C6 分钟前
QT窗口相关控件及其属性
开发语言·qt
CodeCraft Studio6 分钟前
Excel处理控件Aspose.Cells教程:使用 Python 在 Excel 中进行数据验
开发语言·python·excel
.生产的驴10 分钟前
SpringBoot 封装统一API返回格式对象 标准化开发 请求封装 统一格式处理
java·数据库·spring boot·后端·spring·eclipse·maven
火柴盒zhang11 分钟前
websheet之 编辑器
开发语言·前端·javascript·编辑器·spreadsheet·websheet
猿周LV18 分钟前
JMeter 安装及使用 [软件测试工具]
java·测试工具·jmeter·单元测试·压力测试
景天科技苑19 分钟前
【Rust】Rust中的枚举与模式匹配,原理解析与应用实战
开发语言·后端·rust·match·enum·枚举与模式匹配·rust枚举与模式匹配
晨集20 分钟前
Uni-App 多端电子合同开源项目介绍
java·spring boot·uni-app·电子合同
时间之城22 分钟前
笔记:记一次使用EasyExcel重写convertToExcelData方法无法读取@ExcelDictFormat注解的问题(已解决)
java·spring boot·笔记·spring·excel
阿让啊24 分钟前
C语言中操作字节的某一位
c语言·开发语言·数据结构·单片机·算法
椰羊~王小美29 分钟前
LeetCode -- Flora -- edit 2025-04-25
java·开发语言