【LeetCode笔记】3. 无重复字符的最长子串(JAVA、滑动窗口、字符串)

文章目录

  • 题目描述
  • 思路 && 代码
      • 1. 之前的版本
      • 更新 2.0

题目描述

  • 子串:各字符间必须要相邻,而非子序列
  • 使用滑动窗口来做就行
    在这里插入图片描述

思路 && 代码

1. 之前的版本

  • 思路:维护一个滑动窗口,滑动窗口中容纳一个无重复字符的子串。
  • 滑动窗口左边界移动的情况:
    1. 【abc】 a => a【bca】
    2. 【abcd】 c => abc【dc】
  • 其实以上两种情况殊途同归,都是把左边界换成当前判断字符在HashMap中对应的下标的位置的后一个
    然后把前面的字符全都丢弃即可(在HashMap中remove())。
  • 左边界移动的情况,需要进行长度的判断:当前滑动窗口长度可能会改变,如果比当前存储的最大长度要大,那么就需要更新。
  • 为什么可以这样子:特别记录一下,这道题其实老早就通过了。。但是之后考虑情况多了,出现了觉得自己写的代码其实考虑不周,但是就是过了的情况= =。
    主要是有这个注意点:在上面的左边界移动情况2,考虑到abc都被丢弃,但是有没有可能a、b实际上可能可以创造最长子串呢? 答案是没有,因为实际上最多的长度【abcd】已经被记录下来了,b最多就是【bcd】c的情况,a也同理,因此已经可以直接丢弃掉了。
class Solution {public int lengthOfLongestSubstring(String s) {int len=0, lenNow=0;HashMap<Character,Integer> hashMap = new HashMap<>();for(int i=0;i<s.length();i++){if(hashMap.containsKey(s.charAt(i))){// 和left.char相同的情况下,可以继续// 这个if是个优化,但是其实删掉也可以,之后的代码对于这种情况达到一样的效果if(hashMap.get(s.charAt(i))==i-lenNow){hashMap.put(s.charAt(i),i);continue;}// 否则需要把前面的全删了len = Math.max(len,lenNow);// 获取当前重复值的下标。int temp = hashMap.get(s.charAt(i));// 维护哈希表:把不需要的映射remove掉。for(int j = i-lenNow;j<=temp;j++){hashMap.remove(s.charAt(j),j);}// 更新当前滑动窗口的长度lenNow = i - temp;hashMap.put(s.charAt(i),i);}else{hashMap.put(s.charAt(i),i);lenNow++;}}// 一直数到字符串结束的情况,补一个补充return Math.max(len,lenNow);}
}
  • 时间复杂度:O(N),实际上整个流程本质上就是对字符串的每一个元素都必然访问一次可能删除一次
  • 空间复杂度:O(字符集的大小),因为我们需要简历哈希表,而表最大的情况下会容纳整个字符集(及对应下标)。

更新 2.0

  • 比较精简的代码
class Solution {public int lengthOfLongestSubstring(String s) {// initint len = s.length();int max = 0;char[] arr = s.toCharArray();// <字符,字符出现下标>Map<Character, Integer> hashmap = new HashMap<>();int windowLeft = 0;for(int i = 0; i < len; i++) {// Case 1 重复if(hashmap.containsKey(arr[i])) {int index = hashmap.get(arr[i]);for(int j = windowLeft; j <= index; j++) {hashmap.remove(arr[j]);}windowLeft = index + 1;hashmap.put(arr[i], i);}// Case 2 没重复else {hashmap.put(arr[i], i);max = Math.max(max, hashmap.size());}}return max;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/504617.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

启动java服务时刷新缓存_Spring java项目对外提供服务和java进程启动时bean,内部缓存加载的先后关系?...

Spring java项目对外提供服务有这么几种&#xff0c;一种是web服务&#xff0c;譬如tomcat&#xff0c;一种是RPC服务&#xff0c;譬如dubbo&#xff0c;thrift。总的来说就是对外开放某个/些端口&#xff0c;接收请求。Spring工程项目启动时&#xff0c;bean会加载&#xff0c…

【LeetCode笔记】5.最长回文子串(Java、动态规划、字符串)

文章目录题目描述解法 & 代码&#xff1a;思路题目描述 回文&#xff1a;正着念和倒着念一样。 解法 & 代码&#xff1a; 一开始看到子串&#xff0c;想着可能no.3最长重复子串一样用滑动窗口。不过回文串的判断会很麻烦&#xff0c;于是舍弃。之后看题解&#xff…

java 拷贝替换文件夹_比较两个不同文件夹中的两个文件,并将其替换为较新的文件夹...

如果要根据上次修改日期覆盖&#xff0c;则 File 对象具有所需的属性&#xff1a; DateLastModified . (您可以检查 File 对象的所有属性here . )您已经可以访问源文件对象(代码的 Photo 变量)&#xff0c;因此您只需要获取目标的文件对象 .这样的事情应该有效&#xff1a;Dim …

【LeetCode笔记】6. Z字形变化(JAVA、思路)

文章目录题目描述解题 & 代码二维数组ArrayList && StringBuilder题目描述 这题目有点搞&#xff0c;理解题意得时候直接结合给的例子比较好。本质就是&#xff1a;从顶部开始&#xff0c;往下逐个走&#xff1b;到底了就反向&#xff0c;往上逐个走&#xff1b;以…

用java写四则混合运算,JAVA写的四则混合运算-JSP教程,Java技巧及代码

这是一个四则混合运算程序,没什么做优化,也没做什么注释,(人啊,总喜欢偷懒的.)这个版本我已经定为了2.21版本.呵呵.从最先的1.0到2.0的改动很大.除了运算思想没动处,其它的都在2.0做了重新设计.这种程序其实网上一大把(算法也好得多)。此仅为无聊找点事情做而已。/***四则混合运…

【LeetCode笔记】7.整数反转(Java、溢出判断、栈)

文章目录题目描述解法 & 代码① 字符串解法② 类栈做法题目描述 边界比较需要考虑&#xff0c;而且还有不允许64位整数的要求。 解法 & 代码 ① 字符串解法 起初想到的做法&#xff0c;不过缺点比较多首先用到了long&#xff0c;实际上不允许使用&#xff0c;修改…

java 接口中变量修饰符,Java的访问修饰符与变量的作用域讲解

Java访问修饰符(访问控制符)Java 通过修饰符来控制类、属性和方法的访问权限和其他功能&#xff0c;通常放在语句的最前端。例如&#xff1a;?Java 的修饰符很多&#xff0c;分为访问修饰符和非访问修饰符。本节仅介绍访问修饰符&#xff0c;非访问修饰符会在后续介绍。访问修…

【LeetCode笔记】11.盛最多水的容器(Java、双指针法)

文章目录题目描述代码 & 解题思路题目描述 无 代码 & 解题思路 思路&#xff1a;使用左右两个指针&#xff0c;不断缩小范围&#xff0c;并在每次缩小的过程对最大值进行更新。代码实现不难&#xff0c;主要是弄明白为啥这样做就能得到正确的值简单描述就是&#x…

php 类加载,关于PHP中类的加载

类的访问方式有两种&#xff1a;通过实例化对象访问类成员访问而访问的前提便是内存中有类的存在&#xff0c;所以需要提前将类加载至内存中。1.手动加载//类文件 Salary.phpclass Salary{public function Student(){echo "Salary下面的Student方法";}}?>应用文件…

【LeetCode笔记】15.三数之和(JAVA、双指针)

文章目录题目描述代码 & 解题思路二刷更新题目描述 主要是解决重复的问题&#xff1a;如何去除重复解、在有大量重复解的情况下如何让算法跑得更快 代码 & 解题思路 先排序&#xff0c;按照大小顺序来做。思路&#xff1a;固定第一个数&#xff0c;用双指针分别代表…

php 网站计数器,PHP实现网站访问量计数器

简单的网站访问量计数器实现&#xff0c;具体如下首先说明思路&#xff1a;1.用户向服务器发出访问请求2.服务器读取访问次数文件&#xff0c;1&#xff0c;向客户端返回3.服务器保存新的浏览次数4.新用户访问&#xff0c;重复123即可解决方案(主要算法)&#xff1a;1.数据文件…

【LeetCode笔记】17.电话号码的字母组合(Java、DFS)

文章目录题目描述代码 & 思路题目描述 得建立映射&#xff0c;其实用数组来建立也行&#xff0c;看起来还比较直观。 代码 & 思路 理好DFS的过程就行&#xff0c;整体思路不难当递归字符length 1时&#xff0c;递归结束 class Solution {public List<String&g…

php ajax download,通过Ajax和PHP强制下载

小编典典您无法使用Ajax下载文件。因此&#xff0c;如果您在ajax上发生了某些情况&#xff0c;则应返回url作为响应&#xff0c;并像document.location "url"开始下载过程一样应用它。这里有一个音符。我记得&#xff0c;如果不是用户单击启动浏览器&#xff0c;浏览…

【LeetCode笔记】19.删除链表的倒数第N个结点(Java、快慢指针)

文章目录题目描述思路 & 代码题目描述 重点在于一趟扫描实现简单的做法&#xff1a;一趟扫描长度&#xff0c;一趟根据长度找到结点删除 思路 & 代码 两种特例情况&#xff0c;见注释思路&#xff1a;根据N构造两个快慢指针&#xff0c;两指针直接差了N个结点。由此…

java xca碗组口径,公路车常见杂音检查清单和解决方法(图文)

爱车上出现杂音是件很不爽的事&#xff0c;我本人就很不能容忍任何异响。相信这也是困扰广大车友的问题之一&#xff0c;于是我根据自己和周围车友的经验以及网上的资源&#xff0c;整理出这份清单&#xff0c;希望能给遇到此类问题的车友们一些帮助。写在前面&#xff1a;当异…

【LeetCode笔记】20.有效的括号(Java、栈) 21. 合并两个有序链表(Java)

文章目录20. 题目描述 & 解题21. 题目描述 & 解题1. 一开始的写法2. 参考大佬的写法两道简单类型连着&#xff0c;就直接一起写了。 20. 题目描述 & 解题 括号题是真挺烦人的。。。经典题目了&#xff0c;在学数据结构到栈的时候也会写到类似的题目其实主要就是&a…

matlab将数扩大为整数,MATLAB如何完成大整数运算问题?

Forcal&#xff0b;HugeCalc可以计算下面的数(只有指数部分不能是大整数)&#xff1a;(1000!)^1000%(2000!)代码&#xff1a;!using["HugeCalc"];mvar:i: oo{aHI[0].Fac[1000], //1000!bHI[0].Fac[2000], //2000!printff["\r\n"],[Pow(a,1000)%b].Show[]…

【LeetCode笔记】22.括号生成(Java、DFS回溯、剪枝、括号)

文章目录题目描述代码 & 解法题目描述 先吐槽&#xff1a;括号题好恶心。。括号有效判断需要考虑考虑 代码 & 解法 思路&#xff1a;把括号分开看&#xff0c;这道题和20.有效的括号其实是有差别的&#xff1a;这道题的括号是成对的&#xff0c;而20题的括号则没有…

【LeetCode笔记】23.合并K个升序列表(Java、分治、链表)

文章目录题目描述解法 & 代码二刷冲的第一道hard&#xff0c;好耶&#xff01; 题目描述 这道题和前面的合并两个有序链表很有联系。直接调用了整个合并函数。可以看成我们已经有了足够优秀的“两条链表合并“的函数&#xff0c;然后考虑对K条链表如何进行合并分配。结构类…

php删除一张表数据的时候 把另一张表的数据也删除,剔除第一张表的数据时,修改第二张表的相关字段的数值...

删除第一张表的数据时&#xff0c;修改第二张表的相关字段的数值表xfxf_id vip total1 1 102 1 1003 2 804 3 50表vipvip jifen1 10002 5003 800$sql "delete from " . $fdyu->table(xf) ." WHERE xf_id " . db_create_in(join(,, $_POST[checkboxes])…