C++速通LeetCode中等第5题-无重复字符的最长字串

字串substr法,定义字串的头部和长度,和字串后一位对比,如果不存在重复元素则长度+1,存在重复元素则头部更新,长度重置。

cpp 复制代码
class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        string s2;//存放s的前一部分,判断该部分有没有后一个字符
        int res = 1;
        int start = 0;//子序列第一个的序号
        int len = 1;//连续的前端子序列长度
        if(!s.size()) return 0;
        if(s[0] == ' ') return 1;
        for(start = 0; ; )
        {   
            if(start+len == s.size()) return res;
            s2 = s.substr(start,len);//一开始存放第一个字符
            if(count(s2.begin(),s2.end(),s[start+len]))//判断有没有重复,重复就重新开始计数
            {
                start += 1;//重复则start变到尾部后一位
                res = max(res,len);
                len = 1;
            }
            else//不重复start不变
            {
                len++;
                res = max(res,len);
            }
        }
        return res;
    }
};
相关推荐
学习是生活的调味剂15 小时前
nacos原理之服务注册浅析
java·开发语言·nacos·注册中心
MR_Promethus15 小时前
【C++11】condition_variable 条件变量
c++·条件变量·并发编程
带娃的IT创业者15 小时前
解密OpenClaw系列11-OpenClaw自动更新系统
开发语言·软件工程·自动更新·软件发布·ai智能体·openclaw·桌面智能体
智者知已应修善业15 小时前
【排列顺序判断是否一次交换能得到升序】2025-1-28
c语言·c++·经验分享·笔记·算法
fpcc15 小时前
并行编程实战——CUDA编程的内存建议
c++·cuda
编程小风筝16 小时前
编写java代码如何写文档注释?
java·开发语言
lly20240616 小时前
HTML 媒体(Media)
开发语言
一个处女座的程序猿O(∩_∩)O16 小时前
Python函数参数*args和**kwargs完全指南:从入门到精通
开发语言·python
与衫16 小时前
如何将SQLFlow工具产生的血缘导入到Datahub平台中
java·开发语言·数据库
m0_5312371716 小时前
C语言-分支与循环语句练习
c语言·开发语言