力扣题目-无重复字符的最长子串(C++,python,java)

简介: 力扣题目-无重复字符的最长子串(C++,python,java)

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


示例 :


输入: “abcabcbb”

输出: 3

解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。


C++


1.滑动窗口(双指针法)+hash

一开始联想到kmp,然后发现实际还是双指针法的运用,最后看题解这也叫滑动窗口,确实和计网中的滑动窗口挺像

思路是从开始记录两个指针,第一个指针表示从它开始的最长子串长度,第二个通过移动对比前面是否出现过该字符来记录最长长度(利hash思想),len=后-前+1;

其实题目也可以开hash数组(应该更快),这里熟悉一下set,用unordered_set来做映射

时间复杂度O(n),空间O(1)

class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        unordered_set<char> hash;
        int n=s.length(); 
        if(n<2)return n;
        int k=0,ans=1;
        for(int i=0;i<n;i++){
            while(k<n&&!hash.count(s[k])){
            hash.insert(s[k]);
           ans=max(ans,k-i+1);
            k++;
            }
             hash.erase(s[i]);
             if(n-i<ans)break;//剪枝
        }
        return ans;
    }
};


Python


class Solution:
    def lengthOfLongestSubstring(self, s: str) -> int:
        ans=0
        left=0
        right=0
        hashset=set([])
        n=len(s)
        while left<n:
            while right<n and s[right] not in hashset:
                hashset.add(s[right])
                ans=max(ans,right-left+1)
                right+=1
            hashset.remove(s[left])
            left+=1
            if n-left <ans:
                break
        return ans


java


class Solution {
    public int lengthOfLongestSubstring(String s) {
        Set<Character> hashset=new HashSet<Character>();
        int ans=0,k=0;
        int n=s.length();
        for(int i=0;i<n;i++){
            while(k<n && hashset.contains(s.charAt(k))==false){
                hashset.add(s.charAt(k));
                ans=Math.max(ans,k-i+1);
                k++;
            }
            hashset.remove(s.charAt(i));
        }
        return ans;
    }
}
相关文章
|
2月前
|
人工智能 安全 Java
Java和Python在企业中的应用情况
Java和Python在企业中的应用情况
82 7
|
3月前
|
数据采集 缓存 Java
Python vs Java:爬虫任务中的效率比较
Python vs Java:爬虫任务中的效率比较
|
1月前
|
Java Android开发 C++
Java和C++
Java和C++
47 15
|
2月前
|
Java 程序员 开发工具
在比较Java和Python哪个更易学
在比较Java和Python哪个更易学
45 4
|
2月前
|
Java 程序员 Python
Java和Python
Java和Python
29 2
|
3月前
|
C++ Python
探索Python与C/C++混合编程的艺术
探索Python与C/C++混合编程的艺术
61 1
|
3月前
|
Java Python
如何通过Java程序调用python脚本
如何通过Java程序调用python脚本
53 0
|
3月前
|
安全 Java Python
基于python-django的Java网站全站漏洞检测系统
基于python-django的Java网站全站漏洞检测系统
43 0
|
4月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
5月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
136 2