首页 > 其他 > 详细

leetcode题解#3:无重复字符的最长子串

时间:2021-05-15 12:35:23      阅读:10      评论:0      收藏:0      [点我收藏+]

leetcode题解:无重复字符的最长子串

题目

给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。

示例 1:

输入: s = "abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。

思路

  1. 构造子串的首尾指针。

  2. 判断子串是否重复的方法:利用string的find_first_of方法,传入子串的最后一个字符,当返回的下标非子串的长度,即end-begin,则表明已经重复。

  3. 若重复:则判断长度,比当前记录的最大值大,则覆盖,并重置首尾指针。

  4. 不重复:则尾指针++,继续判断下一个字符。

  5. 循环出口判断条件尾末尾指针大于原字符串长度。

  6. 其中字符串的赋值利用了string的assign方法,注意传入的第三个参数是子串长度,而不是末尾下标。

代码

class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        int max=0,begin=0,end=1; // 初始化参数
        string temp; // 存储子串
        temp.assign(s,begin,end-begin+1); // assign(string,begin,count); 初始化 
        
        while(end <= s.length()){ // 出口,末尾指针超出范围
            if(temp.find_first_of(s[end]) != (end-begin) ){ // 重复判定
                if((end-begin) > max) // 判断长度
                    max = (end-begin);
                begin = begin +1; // 重新开始
                end = begin +1;
            }else{
                end++; // 增加长度
            }
                temp.assign(s,begin,end-begin+1); // 继续赋值
        }
        return max;
    }
};

 

 

 

leetcode题解#3:无重复字符的最长子串

原文:https://www.cnblogs.com/linkcxt/p/14770973.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!