LeetCode题解 || Longest Substring Without Repeating Characters (O(n)算法)问题
problem:
Given a string, find the length of the longest substring without repeating characters.
For example, the longest substring without repeating letters for "abcabcbb" is "abc",
which the length is 3. For "bbbbb" the longest substring is "b", with the length of 1.
thinking:
(1)寻找子串,要做一次遍历。
(2)暴力破解法,检查每个子串,利用hash table的映射思想。开一个数组,下标为字符的ASCII码,因为没有说明字符串的类型,能够採取一些措施压缩hash table的大小。暴力破解法的最坏时间复杂度为O(n*n)
(3)发现一个O(n)的算法。非常赞
事实上,这里非常多工作都是反复的、没用的。
看一个样例:
S="abbdeca"。
t1="abbdeca",t1[1]==t1[2]。
t2="bbdeca"。t2[0]==t2[1]。
t3="bdeca",一直扫描到最后。
t4="deca"、t5、t6、t7都同上。
我们在处理t1的时候已经扫描到了s[2],然后处理t3的时候扫描了s[2]到s[6],这两个子串已经扫描完了整个母串。
换言之,能使得子串停止扫描的位置仅仅有两处:1.s[2]。2.s[6](结尾)。
对于还有一个样例S="aaab",能使子串停止扫描的位置各自是:s[1],s[2],s[3](结尾)。
所以我们能够考虑仅仅扫描母串,直接从母串中取出最长的无反复子串。
对于s[i]:
1.s[i]没有在当前子串中出现过。那么子串的长度加1;
2.s[i]在当前子串中出现过,出现位置的下标为j。那么新子串的起始位置必须大于j,为了使新子串尽可能的长,所以起始位置选为j+1。
code:
说明:凝视的解法复杂度为O(n*n),没凝视的位O(n)
#include <iostream>
#include <string>
#include <memory.h> using namespace std;
/*
class Solution {
public:
int lengthOfLongestSubstring(string s) {
int a[100]; //压缩hash table
memset(a,0,sizeof(int)*100);
int length = s.size();
int index=0;
int max=0;
for(int i=0;i<length;i++)
{
int j=i;
while((j<length)&&(a[s.at(j)-32]==0))//压缩hash table
{
a[s.at(j)-32]=1;
index++;
j++;
}
memset(a,0,sizeof(int)*100);
max=(max>index)?max:index;
index=0;
if(j==length-1) //这里也有一个小技巧。能够有效减少时间复杂度
break;
}
return max;
}
};
*/
class Solution {
public:
int lengthOfLongestSubstring(string s) {
// Start typing your C/C++ solution below
// DO NOT write int main() function
int locs[256];//保存字符上一次出现的位置
memset(locs, -1, sizeof(locs)); int idx = -1, max = 0;//idx为当前子串的開始位置-1
for (int i = 0; i < s.size(); i++)
{
if (locs[s[i]] > idx)//假设当前字符出现过,那么当前子串的起始位置为这个字符上一次出现的位置+1
{
idx = locs[s[i]];
} if (i - idx > max)//这里是关键! !!!!! ! !!
{
max = i - idx;
} locs[s[i]] = i;
}
return max;
}
};
int main()
{
string str = "abcdab";
Solution mysolution;
cout<<mysolution.lengthOfLongestSubstring(str)<<endl; }
LeetCode题解 || Longest Substring Without Repeating Characters (O(n)算法)问题的更多相关文章
- [LeetCode 题解]: Longest Substring Without Repeating Characters
Given a string, find the length of the longest substring without repeating characters. For example, ...
- LeetCode题解——Longest Substring Without Repeating Characters
题目: 给定一个字符串,返回其中不包含重复字符的最长子串长度. 解法: 维持两个指针,第一个指向子串开始,第二个负责遍历,当遍历到的字符出现在子串内时,应计算当前子串长度,并更新最长值:然后第一个指针 ...
- C++版- Leetcode 3. Longest Substring Without Repeating Characters解题报告
Leetcode 3. Longest Substring Without Repeating Characters 提交网址: https://leetcode.com/problems/longe ...
- [Leetcode Week1]Longest Substring Without Repeating Characters
Longest Substring Without Repeating Characters题解 原创文章,拒绝转载 题目来源:https://leetcode.com/problems/longes ...
- LeetCode 3 Longest Substring Without Repeating Characters(最长不重复子序列)
题目来源:https://leetcode.com/problems/longest-substring-without-repeating-characters/ Given a string, f ...
- LeetCode 3 Longest Substring Without Repeating Characters 解题报告
LeetCode 第3题3 Longest Substring Without Repeating Characters 首先我们看题目要求: Given a string, find the len ...
- [LeetCode] 3. Longest Substring Without Repeating Characters 解题思路
Given a string, find the length of the longest substring without repeating characters. For example, ...
- [LeetCode][Python]Longest Substring Without Repeating Characters
# -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com'https://oj.leetcode.com/problems/longest ...
- LeetCode之Longest Substring Without Repeating Characters
[题目描述] Given a string, find the length of the longest substring without repeating characters. Exampl ...
随机推荐
- spy++ 句柄消息详解
使用spy++捕获到的消息详解 主要是今天正好自己用到. 原来也有用过SPY++查看消息,然后自己SendMessage或者PostMessage 直接发送消息给目标程序.但是原来一用就有效果,今天要 ...
- JS中的数据类型及判断数据类型的方法
简单类型(基本类型): number,string,boolean,null,undefined 复杂类型(引用类型):object typeof 只能判断基本数据类型 instanceof 能够判断 ...
- NOIP 2013 T2 火柴排队 ---->求逆序对
[NOIP2013T2]火柴排队 背景 noip2013day1 描述 涵涵有两盒火柴,每盒装有 n 根火柴,每根火柴都有一个高度. 现在将每盒中的火柴各 自 排成一列, 同一列火柴的高度互不相同, ...
- A - Antipalindrome
Problem description A string is a palindrome if it reads the same from the left to the right and fro ...
- RMS:均方根值,RMSE:均方根误差,MSE:标准差
.均方根值(RMS),有时也称方均根.效值.英语写为:Root Mean Square(RMS). 美国传统词典的定义为:The square root of the average of squar ...
- BZOJ1222: [HNOI2001]产品加工(诡异背包dp)
Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 907 Solved: 587[Submit][Status][Discuss] Descriptio ...
- Java基础6一面向对象
面向对象的编程思想:是以事物的整体的为基本单位,从事物的属性和行为两个方面进行描述. 特点: Java来源于生活服务于生活 用面向对象的思想能够接近正常的思维方式. 面向对象语言中有设计模式一说. 在 ...
- TD中INPUT的宽度设置
最近在用C#做Web程序时,碰到一个问题: 将TextBox的asp控件放在Table中的TD里面时,不设置宽度,自动会将TD撑的很大. 查看运行后页面的源代码发现,其实TextBox控件最终在客户端 ...
- 【领略RxSwift源码】- 变换操作(Operators)
在上一篇中,我们分析了在RxSwift中的整个订阅流程.在开讲变换操作之前,首先要弄清楚Sink的概念,不清楚的同学可以翻看上一篇的分析.简单的来说,在每一次订阅操作之前都会进行一次Sink对流的操作 ...
- input左减右加
<!DOCTYPE html><html lang="zh"><head> <meta charset="UTF-8" ...