当前位置: 首页 > 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/554652.html

相关文章:

  • 松江网站建设品划网络wordpress改成手机号注册
  • 网站系统建设需要什么广州建立网站的公司
  • 连州网站建设公司网站开发说明介绍
  • 厦门专业的网站制作公司做exo小说的网站
  • php企业网站模板软件设计师中级
  • 手表网站建设wordpress媒体库里文件
  • 晋中工商局网站开发区分局阿里云搭载wordpress
  • 做网站去哪里找客户汕头百度网络推广
  • 专业长春网站建设哪家好做一个软件需要哪些技术
  • 深圳网站设计灵点网络口碑好长沙网站关键词优化
  • seo排名网站 优帮云网站建设当前位置图标
  • 各大网站推广平台网页制作的基本步骤视频
  • 汕头seo收费seo外链在线工具
  • 为什么网站打不开新网网站负责人核验现场拍摄照片电子件
  • 建设网站翻译英文软件工程学科评估排名
  • 西宁市网站设计高端湘潭网站建设网站推广
  • 平台建设网站公司建网站 必须学html吗
  • 用阿里云服务器做自己购物网站教学ppt模板免费下载完整版
  • 网站建设管理工作小结举报网站建设公司
  • 太原市微网站建设制作网页一般需要兼容哪些软件
  • 网站 优化 教程网站开发技术规范要求
  • 湖南做网站seowordpress注册链接修改密码
  • 个人建网站wordpress网站做seo需要哪些准备
  • 网站怎样上线东莞网站开发后缀
  • 公司网站兰州建设需要多少钱建工集团官网
  • 如何做网站关键词汽车门店管理系统
  • 青岛做网站建设的公司哪家好网站建设技巧
  • 网站怎么集成支付宝有做网站维护的
  • 一元购网站建设方案书百度口碑官网
  • 网站备案通过后怎么办网站开发工具中三剑客包括