内容简介:原题地址:明显还是变宽滑动窗口,窗口用字符数组来做(这次是+1入窗口,-1出窗口),然后我们可以滑动right扩大窗口,出现重复字符就保存在一个hashmap里,只要重复字符存在,我们就滑动left减小窗口,没有了重复字符,我们就比较下窗口字符串是不是目前最短的。代码如下:
原题地址: https://leetcode.com/problems/longest-substring-without-repeating-characters/
要求如下:
给定一个字符串,找出最长的没有重复字符的子串。
例 1:
输入为: “abcabcbb”
输出位: 3
答案是”abc”,长度为3。
例 2:
输入为: “bbbbb”
输出位: 1
答案是”b”,长度为1。
例 3:
输入为: “pwwkew”
输出位: 3
答案是”wke”,长度为3。
明显还是变宽滑动窗口,窗口用字符数组来做(这次是+1入窗口,-1出窗口),然后我们可以滑动right扩大窗口,出现重复字符就保存在一个hashmap里,只要重复字符存在,我们就滑动left减小窗口,没有了重复字符,我们就比较下窗口字符串是不是目前最短的。
代码如下:
本题代码地址为: https://github.com/tinyfool/leetcode/tree/master/src/p0003
本文假设你对滑动窗口概念有所了解,如果你对滑动窗口的概念不够了解,请参看我介绍 滑动窗口的文章,里面有详细的解释 。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
C程序设计语言
(美)Brian W. Kernighan、(美)Dennis M. Ritchie / 徐宝文、李志译、尤晋元审校 / 机械工业出版社 / 2004-1 / 30.00元
在计算机发展的历史上,没有哪一种程序设计语言像C语言这样应用广泛。本书原著即为C语言的设计者之一Dennis M.Ritchie和著名计算机科学家Brian W.Kernighan合著的一本介绍C语言的权威经典著作。我们现在见到的大量论述C语言程序设计的教材和专著均以此书为蓝本。原著第1版中介绍的C语言成为后来广泛使用的C语言版本——标准C的基础。人们熟知的“hello,World"程序就是由本书......一起来看看 《C程序设计语言》 这本书的介绍吧!