leetcode 3.无重复字符的最长子串

本题的最经典思路是使用滑动窗口或者动态规划。

例如滑动窗口,建立起始指针和结尾指针。可以保证结尾指针一定是在起始指针右边的。那么只要每次移动结尾指针至有重复字符,然后再移动起始指针。如此重复至遍历完字符串即可。查找窗口里是否存在子串则使用建立哈希表的方法将时间复杂度降为O(1)。

这样子总的时间复杂度就为O(n)。

 

接下来提供我的思路,属于针对本题分析后的巧解。

用一个容量为128大小的整形数组存放每个字符的最后出现位置。例如last['6']=5.说明在当前视角中,‘6’最后出现的位置为s[5]。用start作为窗口的起始位置,要注意,即使元素已经重复出现过了,也有可能上一个重复元素在start的左边,那就没必要更新start。

复制代码
class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        int last[128];
        int start=0;
        int ans=0;
        memset(last,-1,128* sizeof(int));
        for (int i = 0; i < s.length(); ++i) {
            start=max(start,last[s[i]]+1);
            ans=max(ans,i-start+1);
            last[s[i]]=i;
        }
        return ans;
    }
};
复制代码

 

posted @   布羽  阅读(83)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
点击右上角即可分享
微信分享提示