3. 无重复字符的最长子串 JAVA

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

示例 1:

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

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

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

解法一:滑动窗口

设置start 和 end 两个指针,遍历,对字符串数组end每次加一进行扫描,当遇到在新数组中没有的字母,则加入新数组,若扫描发现已经存在,则使原start指针指向位置更新为存在的字母位置+1.
每次对于更新后的end 和star进行长度的更新计算,若长度大于最大长度,则进行更新长度

public int lengthOfLongestSubstring(String s) {
        int start = 0,end = 0,result = 0;
        int temp;
        int maxlength = 0;
        for (;end<s.length();end++) {
        	temp = judge(s,end,start);
        	if (temp != -1)start= temp;
        	maxlength = end-start+1;
        	result = Math.max(result, maxlength);
        }
        return result;    
    }
	
	public int judge (String s,int end,int start) {
		for (;start<end;start++) {
			if (s.charAt(start) == s.charAt(end)) {
				return start + 1;
				
			}
		}
		return -1;
	}

执行结果:
通过
显示详情
执行用时 :
5 ms
, 在所有 Java 提交中击败了
86.82%
的用户
内存消耗 :
38.6 MB
, 在所有 Java 提交中击败了
14.74%
的用户
时间复杂度为O(n^2)

解法二:hashmap

仍然定位两个指针,star 和 end, 不同的是,每次对于end新扫描出来字母,若没有在hashmap中出现过,则保存进去为(key:location)的形式,若存在在hashmap中且value值大于等于strar,则使得star的指向为当前存在的字母位置+1,再将end所指向的字母和位置加入hashmap.

HashMap<Character, Integer>map = new HashMap<Character, Integer>();
	public int lengthOfLongestSubstring(String s) {
		int start = 0,end = 0;
		int max = 0,result = 0;
		for (;end< s.length();end++) {
			if (map.containsKey(s.charAt(end))&&start<=map.get(s.charAt(end))) {//没有考虑到start回指问题导致出错
				start = map.get(s.charAt(end))+1;
				map.put(s.charAt(end), end);
				//存在的话
			}
			else {
				map.put(s.charAt(end),end);
			}
			max = end - start+1;
			result = Math.max(max, result);
		}
		return result;
	}

执行结果:
通过
显示详情
执行用时 :
14 ms
, 在所有 Java 提交中击败了
41.14%
的用户
内存消耗 :
41.5 MB
, 在所有 Java 提交中击败了
5.00%
的用户
时间复杂度为O(n)
空间复杂度为O(n)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值