力扣1445 连续字符

简介: 力扣1445 连续字符

题目

给你一个字符串 s ,字符串的「能量」定义为:只包含一种字符的最长非空子字符串的长度。

请你返回字符串 s能量

 

解题思路

这个问题的解法相对比较简单,可以通过遍历字符串,计算每个字符的连续出现次数,然后找出最大的连续次数即可。

具体步骤:

  1. 初始化变量: 你使用了 ans 表示最终的结果,num 表示当前字符的连续次数。一开始将它们都初始化为1。
  2. 遍历字符串: 通过 for 循环遍历字符串,从第二个字符开始比较当前字符与前一个字符。
  3. 判断是否连续: 如果当前字符与前一个字符相同,说明有连续的字符出现,此时增加 num 的值,并更新 ansnumans 的较大值。
  4. 重置连续次数: 如果当前字符与前一个字符不同,说明连续的字符中断了,此时将 num 重置为1。
  5. 返回结果: 最终返回 ans,即最大的连续次数。

示例

示例1

输入:s = "leetcode"

输出:2

解释:子字符串 "ee" 长度为 2 ,只包含字符 'e' 。

示例2

输入:s = "abbcccddddeeeeedcba"

输出:5

解释:子字符串 "eeeee" 长度为 5 ,只包含字符 'e' 。

提示

 

👉️ 力扣原文

 

class Solution {
    public int maxPower(String s) {
        int ans=1 ,num=1;
        for(int i =1;i<s.length();++i){
            if(s.charAt(i)==s.charAt(i-1)){
                ++num;
                ans=Math.max(ans,num);
            }else{
                num=1;
                }
        }
        return ans;
    }
}

 

详细解读

以下是代码的逐步解释:

  1. 初始化两个变量:ansnum,分别设置为1。ans 用于存储最长连续重复字符的长度,而 num 用于计算当前连续重复字符的长度。
  2. 遍历字符串 s,从索引1开始(因为索引0没有前一个字符可以比较)。
  3. 对于每个索引 i,检查当前字符 s.charAt(i) 是否与前一个字符 s.charAt(i-1) 相同。
  4. 如果它们相同,增加 num 的值,表示当前连续重复字符序列的长度增加了一个。然后,你用 Math.max() 函数更新 ans,如果 num 大于 ans,则将 ans 设置为 num
  5. 如果字符不同,将 num 重置为1,因为新的连续重复字符序列开始了。
  6. 当循环结束时,ans 将包含最长连续重复字符的长度。
  7. 返回 ans 作为结果。

这种解法的时间复杂度是 O(n),其中 n 是输入字符串的长度,因为你只需要遍历一次字符串。空间复杂度是 O(1),因为只使用了常数个变量来保存状态。

相关文章
|
6月前
|
存储 算法 程序员
【Leetcode 程序员面试金典 01.01】判定字符是否唯一 —— 位运算|哈希表
可以使用哈希表或位运算来解决此问题:由题可知s[i]仅包含小写字母,int[26]即能表示字符的出现次数;
|
1月前
|
存储 算法
Leetcode第三题(无重复字符的最长子串)
这篇文章介绍了解决LeetCode第三题“无重复字符的最长子串”的算法,使用滑动窗口技术来找出给定字符串中最长的不含重复字符的子串,并提供了详细的代码实现和解释。
69 0
Leetcode第三题(无重复字符的最长子串)
|
3月前
|
算法
LeetCode第3题无重复字符的最长子串
该文章介绍了 LeetCode 第 3 题无重复字符的最长子串的解法,通过使用 HashSet 记录不重复的子元素,以每个字符开头遍历字符串,遇到重复字符则重新计算,最终找到最长子串,同时提到可以考虑使用 HashMap 降低复杂度。
LeetCode第3题无重复字符的最长子串
|
5月前
|
存储 算法 数据可视化
深入解析力扣161题:相隔为 1 的编辑距离(逐字符比较与动态规划详解)
深入解析力扣161题:相隔为 1 的编辑距离(逐字符比较与动态规划详解)
|
5月前
|
存储 算法 数据可视化
深入解析力扣157题:用Read4高效读取N个字符(多种解法与详细图解)
深入解析力扣157题:用Read4高效读取N个字符(多种解法与详细图解)
|
4月前
|
索引
821.字符的最短距离-力扣(LeetCode)
821.字符的最短距离-力扣(LeetCode)
35 0
|
5月前
|
存储 算法 程序员
力扣经典150题第三十一题:无重复字符的最长子串
力扣经典150题第三十一题:无重复字符的最长子串
32 0
|
5月前
【LeetCode刷题】滑动窗口思想解决问题:长度最小的子数组、无重复字符的最长子串
【LeetCode刷题】滑动窗口思想解决问题:长度最小的子数组、无重复字符的最长子串
|
5月前
|
存储 算法 数据可视化
深入解析力扣159题:至多包含两个不同字符的最长子串(滑动窗口法详细图解)
深入解析力扣159题:至多包含两个不同字符的最长子串(滑动窗口法详细图解)
|
5月前
|
存储 算法 数据挖掘
LeetCode 第三题:无重复字符的最长子串 详解 【3/1000】
LeetCode 第三题:无重复字符的最长子串 详解 【3/1000】