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

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

字符数组和字符串的区别,C语言字符数组和字符串区别详解

开始的想法是在对字符数组设置两个指针,初始化一个在位置0一个在位置1,ans初始化为1(非空),然后1向后找,0不动,取0到1之间的字符串,判断是否重复(这里单独写一个函数,输入字符串,输出是否重复以及重复字符的后一个的位置),不重复的话用后位置减去前位置,再和ans比较,大的话就保留。如果有重复则前位置向后移动一位,后位置在其后面一位,接着判断之间的字符串是否重复。

#include <iostream>
using namespace std; //判断是否有重复
bool re_or_not(string s)
{
int len= s.length();
for(int i=;i<len;i++){
for(int j=i+;j<len;j++){
if(s[i]==s[j]){
std::cout << " true" << std::endl;
return true;
}
}
}
std::cout << " false" << std::endl;
return false;
} int lengthOfLongestSubstring(string s) {
//char* p1=(char*)s.data();
//char* p1=&s[0];
//char* p2=p1+1;
int len=s.length();
//判空
if(len==)
return ;
int num=;
int begin=;
int end=begin+;
int n=;
while(s[end]!='\0'&&s[begin]!='\0'){
if(re_or_not(s.substr(begin,end-begin+))){
begin++;
end=begin+;
std::cout << " 此时begin="<<begin<< " 此时end="<<end<< std::endl;
}
else{
if(end-begin+>num)
num=end-begin+;
std::cout << " 此时begin="<<begin<< " 此时end="<<end<< std::endl;
end++;
}
}
return num;
} int main() {
string s="dewzyqprkqcmgfnrdfoflwsvkhylsfjxlhwlxne";
int n=lengthOfLongestSubstring(s);
std::cout << n << std::endl;
return ;
}

986 / 987 个通过测试用例
状态:超出时间限制

真的尴尬

再来:

优化,不用那个substring函数了

#include <iostream>
using namespace std; //判断是否有重复
bool re_or_not(string s,int begin,int end)
{
int len= begin-end+;
for(int i=begin;i<len;i++){
for(int j=i+;j<len;j++){
if(s[i]==s[j]){
std::cout << " true" << std::endl;
return true;
}
}
}
std::cout << " false" << std::endl;
return false;
} int lengthOfLongestSubstring(string s) {
//char* p1=(char*)s.data();
//char* p1=&s[0];
//char* p2=p1+1;
int len=s.length();
//判空
if(len==)
return ;
int num=;
int begin=;
int end=begin+;
int n=;
while(s[end]!='\0'&&s[begin]!='\0'){
if(re_or_not(s,begin,end)){
begin++;
end=begin+;
std::cout << " 此时begin="<<begin<< " 此时end="<<end<< std::endl;
}
else{
if(end-begin+>num)
num=end-begin+;
std::cout << " 此时begin="<<begin<< " 此时end="<<end<< std::endl;
end++;
}
}
return num;
} int main() {
string s="alqebriavxoo";
int n=lengthOfLongestSubstring(s);
std::cout << n << std::endl;
return ;
}

还是超时间;

再来:

因为所有字符只有256个,所以定义这样一个数组来判断重复就行了,同时,在遇到重复时,begin和end都后移一位

//判断是否有重复并输出位置
bool re_or_not(std::string s,int begin,int end)
{
int re[256]={0};
for(int i = begin; i<end+1; i++){
if(re[s[i]]==0){
re[s[i]]=1;
}
else return true;
}
return false;
}

int lengthOfLongestSubstring(string s) {
int len = s.length();
//判空
if (len == 0) return 0;
int num = 1;
int begin = 0;
int end = begin + 1;
int n = 0;
while (s[end] != '\0'&&s[begin] != '\0'){
if (re_or_not(s, begin, end)){
begin++;
end ++;
}
else{
if (end - begin + 1>num)
num = end - begin +1;
end++;
}
}
return num;
}

执行用时: 612 ms, 在Longest Substring Without Repeating Characters的C++提交中击败了0.98% 的用户
内存消耗: 332.3 MB, 在Longest Substring Without Repeating Characters的C++提交中击败了0.93% 的用户

这时间。。。。。,看来要大改了

还是上面的256的思路

#include <iostream>
#include <unordered_map> using namespace std; int lengthOfLongestSubstring(std::string s) {
int len=s.length();
//判空
if(len==)
return ;
int re[]={};
int num=;
int begin=;
for(int i=;i<len;i++)
{
if(re[s[i]]==||begin>re[s[i]])//不重复,所以要尝试更新num
//这里不仅要考虑对应位置的值为0,同时还要考虑这样的字符串”abbca“,按之前的方法,最后一个a被当作出现过处理了。但实际上这个a也要加入计算的,所以这里要再加上一个判断条件
//那就是如果此时begin>re[s[i]]的左边,也就是说就算重复了,但是新的a出现时,旧的a已经不再最长字符串的考虑范围内了(因为新字符串的begin位置已经在旧a的右边了)
{
if(num<i-begin+)
num=i-begin+;
}
else//重复了,所以要把begin的位置更新到re中对应的字符对应的位置
{
begin=re[s[i]];
}
re[s[i]]=i+;//+1是为了防止出错,因为i是从0开始的,后面的都要判断是否为0,所以要区别开
std::cout << " 此时i=" << i << " 此时num=" << num << std::endl;
}
return num;
} int main() {
std::string s="abbca";
int n=lengthOfLongestSubstring(s);
std::cout << n << std::endl;
return ;
}

执行用时: 32 ms, 在Longest Substring Without Repeating Characters的C++提交中击败了49.69% 的用户
内存消耗: 14.7 MB, 在Longest Substring Without Repeating Characters的C++提交中击败了0.93% 的用户

还可以吧

#leetcode刷题之路3-无重复字符的最长子串的更多相关文章

  1. leetcode刷题第三天<无重复字符的最长子串>

    给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 : 输入: "abcabcbb" 输出: 解释: 因为无重复字符的最长子串是 . 示例 : 输入: &quo ...

  2. leetcode 刷题(3)--- 无重复字符的最长子串

    给定一个字符串,找出不含有重复字符的最长子串的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 无重复字符的最长子串是 "abc",其长度为 ...

  3. leetcode刷题笔记-3. 无重复字符的最长子串(java实现)

    题目描述 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb"输出: 3 解释: 因为无重复字符的最长子串是 "ab ...

  4. LeetCode随缘刷题之无重复字符的最长子串

    欢迎评论区交流. package leetcode.day_12_04; /** * 给定一个字符串 s ,请你找出其中不含有重复字符的最长子串的长度. * <p> * 示例1: * &l ...

  5. LeetCode刷题--无重复字符的最长子串(中等)

    题目描述: 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 " ...

  6. LeetCode 第 3 题:无重复字符的最长子串(滑动窗口)

    LeetCode 第 3 题:无重复字符的最长子串 (滑动窗口) 方法:滑动窗口 滑动窗口模板问题:右指针先走,满足了一定条件以后,左指针向前走,直到不满足条件. 特点:左右指针的方向是一致的,并且是 ...

  7. python刷LeetCode:3.无重复字符的最长子串

    难度等级:中等 题目描述: 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb"输出: 3 解释: 因为无重复字符的最长子串是 ...

  8. Leetcode题库——3.无重复字符的最长子串

    @author: ZZQ @software: PyCharm @file: lengthOfLongestSubstring.py @time: 2018/9/18 20:35 要求:给定一个字符串 ...

  9. LeetCode 第三题--无重复字符的最长子串

    1. 题目 2.题目分析与思路 3.思路 1. 题目 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3 ...

  10. 【LeetCode】Longest Substring Without Repeating Characters(无重复字符的最长子串)

    这道题是LeetCode里的第3道题. 题目描述: 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: ...

随机推荐

  1. 从零开始的全栈工程师——MySQL数据库( Dos命令 ) ( phpstudy )

    MySQL是一个关系型数据库,存在表的概念.结构,数据库可以存放多张表,每个表里可以存放多个字段,每个字段可以存放多个记录. phpstudy使用终端打开数据库的命令行 密码: root 数据库 查看 ...

  2. 洛谷P4632 [APIO2018] New Home 新家(动态开节点线段树 二分答案 扫描线 set)

    题意 题目链接 Sol 这题没有想象中的那么难,但也绝对不简单. 首先把所有的询问离线,按照出现的顺序.维护时间轴来处理每个询问 对于每个询问\((x_i, y_i)\),可以二分答案\(mid\). ...

  3. 【Android】1.0 安卓生猛上手

    1.Android操作系统,由安迪鲁宾发明,原发明用于照相机操作系统,市场反应惨淡,需求不足,后2005年被谷歌收购,用于智能手机操作系统. 2.logo来源:设计师上厕所看到男女厕所区别标志联想创作 ...

  4. angular2-模板驱动表单

    app.module.ts 导入 FormsModule  import { NgModule } from '@angular/core'; import { BrowserModule } fro ...

  5. Don't forget, a person's greatest emotional need is to feel appreciated.

    Don't forget, a person's greatest emotional need is to feel appreciated.莫忘记,人类情感上最大的需要是感恩.

  6. 刚在虚拟机上装的Linux系统,ifconfig后IP地址怎么成了127.0.0.1了

    之前在虚拟机上装了Linux系统,用了一段时间后想删除了重新装一下,然而装完以后ifconfig后,出现的是 [root@localhost ~]# ifconfig lo Link encap:Lo ...

  7. Android自定义之ScrollView下拉刷新

    公司项目,需要用到ScrollView的下拉刷新,一开始使用的时候PullToRefresh三方库的下拉刷新,我比较纠结第三档库,很强大,但是,公司项目的需求,PullToRefresh就不能做到了, ...

  8. Win SDK 标准程序

    //-Registering window class. //-Creating window. //-Creating message loop. //-Implement WndProc func ...

  9. 清理SharePoint 2010的SQL Server 2008 R2日志数据库的方法

    最近发现Sharepoint的数据库磁盘经常满,导致无法保存数据,经检查发现数据磁盘的所有日志文件远远大于数据文件,因此需要收缩日志文件,一开始利用图形化的收缩文件方式,只有收缩数据文件的大小,对于日 ...

  10. 通过 PowerShell 的方式增加虚拟机终结点

    关于虚拟机终结点的概念请阅读:如何设置虚拟机的终结点 本文包含以下内容(本文在名称为"pstest"的虚拟机做测试): 通过 PowerShell 的方式增加终结点 通过 Powe ...