原网址:https://leetcode-cn.com/problems/longest-substring-without-repeating-characters/
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。
示例 1:
输入: s = "abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
示例 2:输入: s = "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。
示例 3:输入: s = "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。
示例 4:输入: s = ""
输出: 0
C# HashSet 用法
HashSet<T>。这个集合类包含不重复项的无序列表。这种集合称为“集(set)”。集是一个保留字,所以该类有另一个名称HashSet<T>。这个名称很容易理解,因为这个集合基于散列值,插入元素的操作非常快,不需要像List<T>类那样重排集合。
HashSet<T>的修改方法 说 明
Add() 如果某元素不在集合中,Add()方法就把该元素添加到集合中。在其返回值Boolean中,返回元素是否添加的信息
Clear() 方法Clear()删除集合中的所有元素
Remove() Remove()方法删除指定的元素
RemoveWhere() RemoveWhere()方法需要一个Predicate<T>委托作为参数。删除满足谓词条件的所有元素
CopyTo() CopyTo()把集合中的元素复制到一个数组中
ExceptWith() ExceptWith()方法把一个集合作为参数,从集中删除该集合中的所有元素
IntersectWith() IntersectWith()修改了集,仅包含所传送的集合和集中都有的元素
UnionWith() UnionWith()方法把传送为参数的集合中的所有元素添加到集中
下表列出了仅返回集的信息、不修改元素的方法。
HashSet<T>的验证方法 说 明
Contains() 如果所传送的元素在集合中,方法Contains()就返回true
IsSubsetOf() 如果参数传送的集合是集的一个子集,方法IsSubsetOf()就返回true
IsSupersetOf() 如果参数传送的集合是集的一个超集,方法IsSupersetOf()就返回true
Overlaps() 如果参数传送的集合中至少有一个元素与集中的元素相同,Overlaps()就返回true
SetEquals() 如果参数传送的集合和集包含相同的元素,方法SetEquals()就返回true
滑动窗口法
以abcabcbb 为例;
(a)bcabcbb -> (ab)cabcbb -> (abc)abcbb -> a(bc)abcbb -> a(bca)bcbb -> ab(ca)bcbb -> ab(cab)cbb -> abc(ab)cbb -> ........
按照这个顺序进行窗口滑动。用Math.max的方法记录最大长度。
public class Solution {
public int LengthOfLongestSubstring(string s) {
HashSet<char> letter = new HashSet<char>();// 哈希集合,记录每个字符是否出现过
int left = 0,right = 0;//初始化左右指针,指向字符串首位字符
int length = s.Length;
int count = 0,max = 0;//count记录每次指针移动后的子串长度
while(right < length)
{
if(!letter.Contains(s[right]))//右指针字符未重复
{
letter.Add(s[right]);//将该字符添加进集合
right++;//右指针继续右移
count++;
}
else//右指针字符重复,左指针开始右移,直到不含重复字符(即左指针移动到重复字符(左)的右边一位)
{
letter.Remove(s[left]);//去除集合中当前左指针字符
left++;//左指针右移
count--;
}
max = Math.Max(max,count); //比较大小,取大的那个
}
return max;
}
}