如何从给定的字符串中找到最长子字符串的长度而不使用 C# 重复字符?
从给定的字符串输入中,通过具有2个指针i和j使用滑动窗口技术。i和j都指向字符串中的同一个字符。遍历字符串并将其添加到列表中。如果找到重复的字符,则将其从列表中删除,否则将其附加到列表中。
示例1
输入 -s="abcabcbb"
输出 -3
说明 -答案是“abc”,长度为3。
示例2
输入 -s="bbbbb"
输出 -1
说明 -答案是“b”,长度为1。
时间复杂度-O(N)
空间复杂度-O(N)
示例
public class Arrays{
public int LongestSubstringWithNoRepeatingCharacters(string s){
List c = new List();
int iPointer = 0;
int jpointer = 0;
int max = 0;
while (jpointer < s.Length){
if (c.Contains(s[jpointer])){
c.Remove(s[iPointer]);
iPointer++;
}
else{
max = Math.Max(c.Count(), max);
c.Add(s[jpointer]);
jpointer++;
}
}
return max;
}
}
static void Main(string[] args){
int res = s.LongestSubstringWithNoRepeatingCharacters("abcabcbb");
Console.WriteLine(res);
} 输出结果2
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短