【LeetCode解答三】Longest Substring Without Repeating Characters问题Java解答
来源:互联网 发布:上海大华电子秤软件 编辑:程序博客网 时间:2024/06/05 19:34
Given a string, find the length of the longest substring without repeating characters.
Examples:
Given “abcabcbb”, the answer is “abc”, which the length is 3.
Given “bbbbb”, the answer is “b”, with the length of 1.
Given “pwwkew”, the answer is “wke”, with the length of 3. Note that the answer must be a substring, “pwke” is a subsequence and not a substring.
题目如上
这次的题意让我理解了一会儿才真正明白什么意思,找到一个最长的不重复的子串,第三个例子中有p的子串无论如何达不到要求,于是便开始写代码了,坎坷有些多,断断续续也是花了两个小时吧。
刚开始的思路就是超级暴力解法,从第一个字符开始遍历,遇到重复的字符串便将子串重新初始化继续遍历,但是发现这种解法太年轻了,因为可能还要往回退指针(不专业,是这个意思凑合看),例如abad中,按照上述解法得出答案一定是2,可实际上的答案应该是3(”bad”),所以又想,如果遇到相同字符,将指针回到除去当前结果串的状态,可后来发现进入了死循环,又以失败告终,并且程序变得看起来十分冗长,于是考虑重新改变解法。突然想到,既然是不重复的字符串的话,可以利用Java中HashSet的特性来解题啊,并且又突然想到之前学习数据结构时的KMP算法还是什么,具体根本想不起来但是想起来有左右两个指针,于是有了如下思路:
- 设置最大符合要求子串长度max为0
- 左右指针指向第一个字符
- 将右指针指向字符放进set,右指针右移
- 右指针遇到重复字符,检查此时set中元素个数与max的值,取最大值赋给max
- 右指针不动,将左指针指向字符移出set,左指针右移
- 检查右指针指向字符是否依然重复,若是,回到5,若否,回到2
- 比较max和最终set中元素个数,取最大值赋给max
- max即为结果
一遍代码写下来之后,自己运行顺利,贴到leetCode上面抱着试一试的心态提交了一下,没想到直接AC了
附上有注释的代码
public int lengthOfLongestSubstring(String s) { //初始化最大长度 int max = 0; //实例化set对象 HashSet<Character> set = new HashSet<Character>(); //左右指针初始化 int left = 0; int right = 0; //遍历终止条件为右指针到头 while(right < s.length()){ //遇到重复字符,注1 for(int i = 0 ; set.contains(s.charAt(right)) ; i ++){ if(max < set.size()){ max = set.size(); } set.remove(s.charAt(left)); left ++ ; } //将右指针指向字符放进set,右指针右移 set.add(s.charAt(right)); right ++; } //比较max和最终set中元素个数,取最大值赋给max max = Math.max(set.size(),max); return max; } /* 注1 因为执行一次之后要重新检查右指针指向字符是否重复,所以索性将检查用for循环实现 如果右指针指向字符有重复,则进入循环 */
回宿舍,再见。
- 【LeetCode解答三】Longest Substring Without Repeating Characters问题Java解答
- [Leetcode] Longest Substring Without Repeating Characters (Java)
- Longest Substring Without Repeating Characters -- Leetcode Java
- [Leetcode]Longest Substring Without Repeating Characters java
- [LeetCode][Java] Longest Substring Without Repeating Characters
- LeetCode java Longest Substring Without Repeating Characters
- LeetCode : Longest Substring Without Repeating Characters [java]
- Java-LeetCode-Longest Substring Without Repeating Characters
- Java Leetcode Longest Substring Without Repeating Characters
- 【LeetCode】 Longest Substring Without Repeating Characters(Java)
- Longest Substring Without Repeating Characters leetcode java
- 【leetcode】3. Longest Substring Without Repeating Characters 三种方法
- [c++] LeetCode longest substring without repeating characters问题
- Leetcode之Longest Substring Without Repeating Characters 问题
- leetcode第三题Longest Substring Without Repeating Characters java
- [LeetCode Java] 3 Longest Substring Without Repeating Characters
- 【leetcode with java】3 Longest Substring Without Repeating Characters
- [leetcode-3]Longest Substring Without Repeating Characters(java)
- MyBatis学习(五)-缓存机制
- webService的简易介绍
- 用Java编写的第一个UDF
- Linux下常用软件分享(TODO)
- Dukto 傻瓜安装教程
- 【LeetCode解答三】Longest Substring Without Repeating Characters问题Java解答
- myabtis 45; 必须声明元素类型 "bind"。
- Migration guide
- HDU6170 Two strings dp 多校联赛第9场
- Linux学习(四):Linux文件系统及其shell命令
- 设置Xshell连不上CentOS虚拟机
- jdbc简单的使用
- mysql导入数据库出现异常(数据库字符集问题),如何解决??
- 时间工具类