前言
从现在开始,学习十二月中LeetCode的题。
业精于勤,荒于嬉;行成于思,毁于随。——韩愈
正题
这是十二月第一道题,它是LeetCode中的1446道题——连续字符,这是一道简单题。
题目:
给你一个字符串 s ,字符串的「能量」定义为:只包含一种字符的最长非空子字符串的长度。
请你返回字符串的能量。
示例:
示例 1:
输入:s = “leetcode”
输出:2
解释:子字符串 “ee” 长度为 2 ,只包含字符 ‘e’ 。
示例 2:
输入:s = “abbcccddddeeeeedcba”
输出:5
解释:子字符串 “eeeee” 长度为 5 ,只包含字符 ‘e’ 。
示例 3:
输入:s = “triplepillooooow”
输出:5
示例 4:
输入:s = “hooraaaaaaaaaaay”
输出:11
示例 5:
输入:s = “tourist”
输出:1
提示:
1 <= s.length <= 500
s 只包含小写英文字母。
思路及解题思路:
这道题的逻辑很简单,很容易看懂。
我们可以创建一个变量count来表示最终中最长的连续字符的长度数,然后再创建一个变量ans用来在判断前后字符是否相等后来计数;
当出现相等的字符时,ans累加并且更新count的值;
当出现不相等的字符时,ans就回复到1,然后再继续进行判断。
具体代码如下所示:
package LeetCode.Twenty_oneYear_Twelve月.Simpleness;
public class LeetCode题_连续字符 {
static String s = "addcccddddeeeeedcba";
public static int maxPower(String s) {
int count = 1;
int ans = 1;
for (int i = 1;i < s.length();i++){
if(s.charAt(i) == s.charAt(i - 1)){
ans++;
count = Math.max(count, ans);
}else {
//检测到出现不是连续字符
//重置ans的值
ans = 1;
}
}
return count;
}
public static void main(String[] args) {
System.out.println(maxPower(s));
}
}