leetcode problem3解题报告
来源:互联网 发布:淘宝店铺导航条背景色 编辑:程序博客网 时间:2024/05/16 04:04
一开始看错了,以为是简单的求不重复的字符的个数,看note才发现,是找到最长不重复字符的“子串”
并没有想到什么办法,在B站看到有人的解题思路,于是尝试用代码实现。
具体方法:
一个maxlen ,一个visited[256]的bool数组
运用两个坐标,分别表示当前子串 在原字符串中的头坐标和为尾坐标,分别为左坐标和右坐标
首先,左坐标不变,右坐标++,
如果visisted[s[right]]==false,变为true,maxlen=max(maxlen,right-left+1)
如果visisted[s[right]]==true,表示该字符串重复,maxlen=max(maxlen,right-left),左坐标++一直到重复字符的下一位,之后进入下一轮循环。
int lengthOfLongestSubstring(string s) {int maxlen = 0;int left = 0;int right = 0;bool visited[256] = {false};if (s.size() == 0) return 0;if (s.size() == 1) return 1;for (left; left < (int)s.size(); left++) {for (right; right < (int)s.size(); right++) {//右指针所指的字符没有访问过if (!visited[s[right]]) {visited[s[right]] = true;maxlen = max(maxlen, right - left + 1);}//右指针所指的字符已经访问过else {maxlen = max(maxlen, right - left);while (s[left] != s[right]) {visited[s[left]] = false;left++;}//此时left和right所指向的字符串相同,让left自加1,进入下一次循环left++;}}}return maxlen;}
阅读全文
0 0
- leetcode problem3解题报告
- LeetCode 解题报告索引
- [LeetCode]Permutations,解题报告
- Leetcode Triangle 解题报告
- [LeetCode]Anagrams,解题报告
- leetCode解题报告
- [LeetCode]Candy, 解题报告
- 【LeetCode】Candy 解题报告
- 【LeetCode】Triangle 解题报告
- 【LeetCode】Permutations 解题报告
- LeetCode 解题报告 LinkedListCycleII
- LeetCode 解题报告 Candy
- 【LeetCode】Anagrams 解题报告
- 【LeetCode】Combinations 解题报告
- 【LeetCode】Subsets 解题报告
- LeetCode 解题报告 LargestNumber
- [LeetCode]DeleteDuplicateEmails,解题报告
- LeetCode-Subsets-解题报告
- Expected a component class, got [object Object]
- 99. Recover Binary Search Tree
- UVA.12034 Race (递推)
- 嵌入式每日学习心得 守护进程
- 基础校验
- leetcode problem3解题报告
- java 总结几种线程异步转同步的方法
- linux学习命令 一
- VS中使用QT,多国语言翻译问题
- JAVA基础知识二
- 上Google 最简单的办法 更改hosts 见laod
- 深入理解Java虚拟机——JVM、DVM(dalvik)和ART之间的区别
- 嵌入式每日学习心得 线程
- Java中Volatile关键字详解