leetcode第三题 最长无重复字符子串

 

这题我通过模仿第一题的做法采用hashmap将时间复杂度降至O(n^2),不过leetcode似乎把时间复杂度降到了O(n),或许这就是大佬写的吧。。。。

我的代码

public int lengthOfLongestSubstring(String s) {
		
		if(s.length() == 0) {
			return 0;
		}else if(s.length() == 1){
			return 1;
		}
		
		Map<Integer, Character> map = new HashMap<Integer, Character>();
		//int k = 0;
		int[] c = new int[s.length()];
		if(s.length() == 0) {
			return 0;
		}
		for(int i = 0;i < s.length();i++) {
			map.clear();
			for(int j = i;j < s.length();j++) {
				if(map.containsValue(s.charAt(j)) == false) {
				   map.put(j, s.charAt(j));
				   c[i] = j - i + 1 ;
				}else {
				   //c[i] = j - i;	
					break;
				}
			
			}
		
		}
		int k = 0;
		for(int i = 0;i < c.length;i++) {
			if(c[i] > c[k]) {
				k = i;
			}
		}
		return c[k]; 
	}

大佬们的

solution 1

public class Solution {
    public int lengthOfLongestSubstring(String s) {
        int n = s.length(), ans = 0;
        Map<Character, Integer> map = new HashMap<>(); // current index of character
        // try to extend the range [i, j]
        for (int j = 0, i = 0; j < n; j++) {
            if (map.containsKey(s.charAt(j))) {
                i = Math.max(map.get(s.charAt(j)), i);
            }
            ans = Math.max(ans, j - i + 1);
            map.put(s.charAt(j), j + 1);
        }
        return ans;
    }
}

solution2 通过使用ASCII实现

public class Solution {
    public int lengthOfLongestSubstring(String s) {
        int n = s.length(), ans = 0;
        int[] index = new int[128]; // current index of character
        // try to extend the range [i, j]
        for (int j = 0, i = 0; j < n; j++) {
            i = Math.max(index[s.charAt(j)], i);
            ans = Math.max(ans, j - i + 1);
            index[s.charAt(j)] = j + 1;
        }
        return ans;
    }
}

 

 

 

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值