当前位置: 首页 > wzjs >正文

济南网站制作设计公司国际时事新闻最新消息

济南网站制作设计公司,国际时事新闻最新消息,网站代码优化,宿州专业网站建设LeetCode 第159题:至多包含两个不同字符的最长子串 题目描述 给定一个字符串 s,找出 至多 包含两个不同字符的最长子串 t,并返回该子串的长度。 难度 中等 题目链接 点击在LeetCode中查看题目 示例 示例 1: 输入: s &qu…

LeetCode 第159题:至多包含两个不同字符的最长子串

题目描述

给定一个字符串 s,找出 至多 包含两个不同字符的最长子串 t,并返回该子串的长度。

难度

中等

题目链接

点击在LeetCode中查看题目

示例

示例 1:

输入: s = "eceba"
输出: 3
解释: t 是 "ece",长度为3。

示例 2:

输入: s = "ccaabbb"
输出: 5
解释: t 是 "aabbb",长度为5。

示例 3:

输入: s = "aaaaa"
输出: 5
解释: t 是 "aaaaa",长度为5。

提示

  • 1 <= s.length <= 105
  • s 由英文字母组成

解题思路

方法:滑动窗口

使用滑动窗口和哈希表来维护不同字符的计数。
关键点:

  1. 使用哈希表记录窗口内字符的出现次数
  2. 当不同字符数超过2时,移动左指针
  3. 更新最大长度
  4. 处理边界情况

时间复杂度:O(n),其中n是字符串长度。
空间复杂度:O(1),因为最多存储3个字符的计数。

代码实现

C# 实现

public class Solution {public int LengthOfLongestSubstringTwoDistinct(string s) {if (string.IsNullOrEmpty(s)) return 0;Dictionary<char, int> dict = new Dictionary<char, int>();int left = 0, maxLen = 0;for (int right = 0; right < s.Length; right++) {char c = s[right];if (!dict.ContainsKey(c)) {dict[c] = 0;}dict[c]++;while (dict.Count > 2) {char leftChar = s[left];dict[leftChar]--;if (dict[leftChar] == 0) {dict.Remove(leftChar);}left++;}maxLen = Math.Max(maxLen, right - left + 1);}return maxLen;}
}

Python 实现

class Solution:def lengthOfLongestSubstringTwoDistinct(self, s: str) -> int:if not s:return 0char_count = {}left = max_len = 0for right, char in enumerate(s):char_count[char] = char_count.get(char, 0) + 1while len(char_count) > 2:left_char = s[left]char_count[left_char] -= 1if char_count[left_char] == 0:del char_count[left_char]left += 1max_len = max(max_len, right - left + 1)return max_len

C++ 实现

class Solution {
public:int lengthOfLongestSubstringTwoDistinct(string s) {if (s.empty()) return 0;unordered_map<char, int> charCount;int left = 0, maxLen = 0;for (int right = 0; right < s.length(); right++) {charCount[s[right]]++;while (charCount.size() > 2) {charCount[s[left]]--;if (charCount[s[left]] == 0) {charCount.erase(s[left]);}left++;}maxLen = max(maxLen, right - left + 1);}return maxLen;}
};

性能分析

各语言实现的性能对比:

实现语言执行用时内存消耗特点
C#92 ms38.2 MB实现简洁,性能适中
Python156 ms16.8 MB代码最简洁
C++24 ms9.6 MB性能最优

补充说明

代码亮点

  1. 使用滑动窗口优化时间复杂度
  2. 使用哈希表维护字符计数
  3. 代码结构清晰,易于维护

常见错误

  1. 没有处理空字符串的情况
  2. 没有正确处理字符计数为0的情况
  3. 边界条件处理不当

相关题目

  • 3. 无重复字符的最长子串
  • 340. 至多包含 K 个不同字符的最长子串
  • 424. 替换后的最长重复字符
http://www.dtcms.com/wzjs/962.html

相关文章:

  • 兰州新区最新消息搜狗seo查询
  • 怎么让百度收录网站百度注册网站怎么弄
  • 邢台做网站公司排名免费公司网站建站
  • 做接口的网站网络营销概述
  • wordpress 歌seo外链平台热狗
  • 网站建设流程总结关键词排名seo优化
  • 男孩子和男孩子在一起怎么做网站西安做网页的公司
  • wordpress白色简约主题自动app优化下载
  • google网站提交网络平台推广方案
  • 网站布局设计规则最新疫情最新消息
  • 创做阿里巴巴网站流程网站怎么推广出去
  • 动画专业大学seo在线外链
  • web网站扫描模板建网站价格
  • 市总工会智慧网站建设总结免费外贸接单平台
  • 宜春网站开发公司电话开鲁网站seo站长工具
  • 三维建模青岛seo网站建设公司
  • 怎么做可以看外国视频网站怎样做好服务营销
  • 网站建设成本分析数字营销公司
  • seo点评类网站打广告推广怎么做
  • 石景山区公司网站建设新手怎么学电商运营
  • 做外贸的专业网站全网推广成功再收费
  • 帮网站做推广赚钱吗合肥百度竞价推广代理公司
  • 在线网站建设收费怎样才能在百度上面做广告宣传
  • 外贸网站建设公司流程推广合作
  • 青岛市南区城市建设局网站移动营销
  • 网站dns修改手机百度网页版
  • 网站开发网络公司兼职seo 优化顾问
  • 帝国cms建设 政府网站排名优化推广
  • 做网站满屏的照片尺寸是多少今日热点新闻2022
  • 安吉做网站女生做sem还是seo