力扣题目-无重复字符的最长子串(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;
    }
}
相关文章
|
16小时前
|
Go C++
【力扣】2696. 删除子串后的字符串最小长度(模拟 栈 C++ Go实现栈)
【2月更文挑战第18天】2696. 删除子串后的字符串最小长度(模拟 栈 C++ Go实现栈)
35 6
|
16小时前
|
存储 计算机视觉 Python
python实现Gif图片的字符画
这是一个Python实战项目,旨在将GIF动态图转化为ASCII字符动画。项目适合有一定Python基础的学习者,主要使用os、imageio、PIL库。首先,代码导入所需库,然后通过PIL创建空白图片并添加文本。接着,程序读取GIF,拆分帧并转为字符画,存入“tmp”目录。同时,代码提供了清空“tmp”目录、将灰度值映射为ASCII字符、将图片处理成字符画的函数。此外,还有创建新画布和合成GIF的步骤。主函数调用这些模块,最终将ASCII字符画合并成GIF。项目展示了将动态图像转换为ASCII艺术的过程。
|
16小时前
|
编解码 JavaScript 前端开发
【专栏】介绍了字符串Base64编解码的基本原理和在Java、Python、C++、JavaScript及Go等编程语言中的实现示例
【4月更文挑战第29天】本文介绍了字符串Base64编解码的基本原理和在Java、Python、C++、JavaScript及Go等编程语言中的实现示例。Base64编码将24位二进制数据转换为32位可打印字符,用“=”作填充。文中展示了各语言的编码解码代码,帮助开发者理解并应用于实际项目。
|
16小时前
|
前端开发 Java Go
开发语言详解(python、java、Go(Golong)。。。。)
开发语言详解(python、java、Go(Golong)。。。。)
|
16小时前
|
C++
面向对象的C++题目以及解法2
面向对象的C++题目以及解法2
31 1
|
16小时前
|
C++
面向对象的C++题目以及解法
面向对象的C++题目以及解法
19 0
|
16小时前
|
存储 C++
[c++]类和对象常见题目详解
[c++]类和对象常见题目详解
16 0
|
16小时前
|
SQL Java 关系型数据库
在Python中编写Java数据库驱动是不可能的
在Python中编写Java数据库驱动是不可能的
|
16小时前
|
索引 Python
Python 超高频常见字符操作【建议收藏】
Python 超高频常见字符操作【建议收藏】
|
16小时前
|
网络协议
《 LeetCode 热题 HOT 100》——无重复字符的最长子串
《 LeetCode 热题 HOT 100》——无重复字符的最长子串

热门文章

最新文章