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

网站有哪些费用多少钱营销团队公司

网站有哪些费用多少钱,营销团队公司,免费网站如何注册,wordpress 公告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/a/421650.html

相关文章:

  • 公司网站域名续费一年多少钱杭州市建设监理协会网站
  • 研究生院 网站 建设网站标题的关键字怎么写
  • 数据分析培训班杭州 seo网站建设 网络服务
  • 京山网站建设荣成市信用建设网站
  • 访客留言网站库尔勒 网站建设
  • 推荐一下网站谢谢摄影展板设计
  • 湖北系统建站怎么用建网站空间可以不买
  • 阿里云linux主机如何添加2个网站企业推广的渠道有哪些
  • 网站设计建设方案云南文山网站建设制作
  • html网页制作企业类网站徐州建站网页建设
  • 自己做服务器的网站wordpress 文章背景色
  • 手机网站怎么布局网页认证
  • 如何申请cn域名做网站wordpress添加页面
  • 长治网站建设哪家好郑州做网络优化的公司
  • wordpress设置2个网站最牛的html5网站建设
  • 金色网站模板头条新闻最新消息
  • iis搭建网站时富阳网站制作
  • wordpress网站分享微信群网站建设seo优化价格
  • 凡科网的网站建设好用吗房地产网站建设提案
  • wordpress 建站公司wordpress装主题失败
  • 用图片做简单网站网站制作培训班
  • 个人网站可以做社交类型视频手机网站开发
  • 淘宝网站建设类直通车wordpress是什么软件
  • 网站开发工程师公司网站建设分金手指排名十二
  • 非常好的资讯网站设计wordpress导入doc
  • 手机制作网站的软件网站建设要如何选择
  • 汕头网站推广找谁建设彩票网站如何盈利
  • 青岛网站关键词推广景点与网站合作方案怎么做
  • 广元城乡建设部网站首页网站如何用微信支付
  • 企业网站需要响应式企信网查询