广告
返回顶部
首页 > 资讯 > 精选 >编程语言中如何实现无重复字符的最长子串
  • 850
分享到

编程语言中如何实现无重复字符的最长子串

2023-06-02 13:06:07 850人浏览 薄情痞子
摘要

小编给大家分享一下编程语言中如何实现无重复字符的最长子串,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!题目:给定一个字符串,请你找出其中不含有重复字符的 

小编给大家分享一下编程语言中如何实现无重复字符的最长子串,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

题目:

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

示例 1:

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

示例 2:

输入: "bbbbb"输出: 1解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。

示例 3:

输入: "pwwkew"输出: 3解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。     请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。

解题思路:

  • 暴力求解, 时间复杂度为 O(n^3), 因为要对所有字符遍历, 对子串遍历确认是否有重复字符, pass

  • 滑动窗口, 维护一个索引 [i,j) 的滑动窗口, 对已存在的字符 i' 直接更新滑动窗口 [i',j), 你需要保留每一个字符值及其索引, 即由字符映射索引位置哈希映射: Key 为字符值, Value 为索引位置字符映射: ASCII 码共 128 个字符, 维护一个长度为 128 的整型数组,数组索引值映射 128 个字符,存储元素值为字符位置

哈希映射:

Java:

class Solution {    public int lengthOfLongestSubstring(String s) {        char[] chars = s.toCharArray();//转为字符数组        if (chars.length == 0) return 0;        HashMap<Character, Integer> map = new HashMap<>();//建立哈希映射        int size = s.length(), count = 0, i = 0;        for (int j = 0; j < size; j++) {//遍历字符            if (map.containsKey(chars[j]))//如果映射中存在该字符                i = Math.max(map.get(chars[j]), i);//更新滑动窗口的左边界 i            count = Math.max(count, j - i);//更新 count 为最大值            map.put(chars[j], j + 1);//更新映射中该字符映射的 Value 值为当前位置加一        }        return count + 1;//返回最大累加总数, 需要加 1    }}

python:

class Solution:    def lengthOfLongestSubstring(self, s: str) -> int:        if not s:            return 0        hash_map = dict() # 建立字典        size = len(s)        i, count = 0, 0        for j, c in enumerate(s): # 枚举字符            if c in hash_map: # 如果映射中存在该字符                i = max(i, hash_map[c]) # 更新滑动窗口的左边界 i            count = max(count, j-i) # 更新 count 为最大值            hash_map[c] = j+1 # 更新映射中该字符映射的 Value 值为当前位置加一        return count+1 # 返回最大累加总数, 需要加 1

字符映射:

Java:

class Solution {    public int lengthOfLongestSubstring(String s) {        char[] chars = s.toCharArray();        if (chars.length == 0) return 0;        int[] index = new int[128];//建立长度为 128 位的 ASCII 码字符映射表        int size = s.length(), count = 0, i = 0;        for (int j = 0; j < size; j++) {//遍历字符            i = Math.max(index[chars[j]], i);//更新滑动窗口的左边界 i            count = Math.max(count, j - i);//更新 count 为最大值            index[chars[j]] = j + 1;//更新映射中该字符所在元素值为当前位置加一        }        return count + 1;//返回最大累加总数, 需要加 1    }}

Python:

class Solution:    def lengthOfLongestSubstring(self, s: str) -> int:        if not s:            return 0        size = len(s)        i, count = 0, 0        index = [0]*128 # 建立长度为 128 位的 ASCII 码字符映射表        for j, c in enumerate(s): # 枚举字符            i = max(i, index[ord(c)]) # 更新滑动窗口的左边界 i            count = max(count, j-i) # 更新 count 为最大值            index[ord(c)] = j+1 # 更新映射中该字符所在元素值为当前位置加一        return count+1 # 返回最大累加总数, 需要加 1

因为 Python 没有字符概念, 需要 ord() 函数转为 ASCII 数字

以上是“编程语言中如何实现无重复字符的最长子串”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

--结束END--

本文标题: 编程语言中如何实现无重复字符的最长子串

本文链接: https://www.lsjlt.com/news/230171.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 编程语言中如何实现无重复字符的最长子串
    小编给大家分享一下编程语言中如何实现无重复字符的最长子串,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!题目:给定一个字符串,请你找出其中不含有重复字符的 ...
    99+
    2023-06-02
  • C++实现无重复字符的最长子串
    目录题目及要求:提示:原创代码:代码思路:题目及要求: 给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。 提示: 0 <= s.length <...
    99+
    2022-11-12
  • C++实现leetcode(3.最长无重复字符的子串)
    [LeetCode] 3. Longest Substring Without Repeating Characters 最长无重复字符的子串 Given a string, fin...
    99+
    2022-11-12
  • C#算法怎么实现无重复字符的最长子串
    这篇文章主要介绍“C#算法怎么实现无重复字符的最长子串”,在日常操作中,相信很多人在C#算法怎么实现无重复字符的最长子串问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C#算法怎么实现无重复字符的最长子串”的疑...
    99+
    2023-06-26
  • 大数据中如何实现无重复字符的最长子串算法
    这篇文章给大家分享的是有关大数据中如何实现无重复字符的最长子串算法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 无重复字符的最长子串         &nbs...
    99+
    2023-06-19
  • LeetCode程序员面试题之无重复字符的最长子串
    目录1.简述:示例 1:示例 2:示例 3:2.代码实现:1.简述: 给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。 示例&nb...
    99+
    2023-02-05
    无重复字符的最长子串 Java实现最长子串的算法 Java程序求解最长子串
  • python如何进行leetcode无重复字符的最长字串的实现
    python如何进行leetcode无重复字符的最长字串的实现,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。无重复字符的最长字串是一道字符串处理算法的题目,在日...
    99+
    2023-06-02
  • 如何进行JS,PY,TS版无重复字符的最长子串分析
    本篇文章给大家分享的是有关如何进行JS,PY,TS版无重复字符的最长子串分析,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。目描述:给定一个字符串,请你找出其中不含有重复字符的&...
    99+
    2023-06-02
  • 汇编语言中如何实现字符串操作
    这篇文章将为大家详细讲解有关汇编语言中如何实现字符串操作,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。软件:emu8086语言:汇编语言(Assembly)注意:小编列出了字符串匹配和字符串...
    99+
    2023-06-21
  • C语言如何实现翻转字符串中的单词
    目录C语言翻转字符串中的单词另外开辟一个空间,来存放翻转的字符串直接在原数组上进行操作C语言字符串各单词的反转思路代码实现代码编译调试输出C语言翻转字符串中的单词 另外开辟一个空间,...
    99+
    2022-11-13
  • java如何实现获取字符串中第一个出现不重复的字符
    比如:输入name输出n,输入teeter输出r,输入namename输出null具体实现代码如下:import java.util.Scanner; public class Main { public static void mai...
    99+
    2020-03-13
    java 获取 字符串 不重复 字符 第一个
  • Django编程中如何实现常用的字符串算法?
    Django是一款优秀的Python web框架,它能够帮助开发者快速构建高质量的web应用。在Django编程中,常常需要使用字符串算法来处理各种字符串相关的问题。本文将介绍Django中常用的字符串算法,并且通过演示代码来说明如何实现这...
    99+
    2023-09-25
    编程算法 django laravel
  • Bash编程中如何实现高效的字符串匹配算法?
    在Bash编程中,字符串匹配是一个非常常见的需求。无论是对文件名的匹配,还是对文本内容的搜索,字符串匹配都是必不可少的。然而,在实际编程中,我们经常会遇到一些字符串匹配效率较低的问题,这给程序的性能带来了很大的影响。本文将介绍Bash编程...
    99+
    2023-08-07
    编程算法 自然语言处理 bash
  • Go语言编程中,如何应对复杂的算法实现?
    Go语言是一门快速发展的编程语言,它以其高效、简洁、安全等特性被广泛使用。但在实际的编程过程中,我们经常会遇到需要处理复杂算法的情况。本文将介绍如何在Go语言编程中应对复杂的算法实现,并结合实例演示相关代码。 一、选择正确的数据结构 在处理...
    99+
    2023-08-08
    编程算法 bash 响应
  • GO语言中的路径编程算法:如何实现重定向功能?
    路径编程算法是一种在计算机科学中常见的算法,它通常用于在网站上实现重定向功能。在GO语言中,实现重定向功能可以使用标准库中的"net/http"包。在本文中,我们将介绍GO语言中如何使用路径编程算法实现重定向功能。 路径编程算法是一种将U...
    99+
    2023-07-23
    path 编程算法 重定向
  • 如何在 Go 语言中编写高质量的 API 文件并实现最佳编程算法?
    Go 语言是一种快速、安全、高效的编程语言,它广泛应用于 Web 开发、网络编程、云计算等领域。在开发过程中,编写高质量的 API 文件和实现最佳编程算法是非常重要的。本文将介绍如何在 Go 语言中编写高质量的 API 文件并实现最佳编程算...
    99+
    2023-06-24
    api 文件 编程算法
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作