美文网首页
【算法题】2730. 找到最长的半重复子字符串

【算法题】2730. 找到最长的半重复子字符串

作者: 程序员小2 | 来源:发表于2023-07-03 07:02 被阅读0次

    题目:

    给你一个下标从 0 开始的字符串 s ,这个字符串只包含 0 到 9 的数字字符。

    如果一个字符串 t 中至多有一对相邻字符是相等的,那么称这个字符串 t 是 半重复的 。例如,0010 、002020 、0123 、2002 和 54944 是半重复字符串,而 00101022 和 1101234883 不是。

    请你返回 s 中最长 半重复 子字符串的长度。

    一个 子字符串 是一个字符串中一段连续 非空 的字符。

    示例 1:

    输入:s = "52233"
    输出:4
    解释:最长半重复子字符串是 "5223" ,子字符串从 i = 0 开始,在 j = 3 处结束。
    示例 2:

    输入:s = "5494"
    输出:4
    解释:s 就是一个半重复字符串,所以答案为 4 。
    示例 3:

    输入:s = "1111111"
    输出:2
    解释:最长半重复子字符串是 "11" ,子字符串从 i = 0 开始,在 j = 1 处结束。

    提示:

    1 <= s.length <= 50
    '0' <= s[i] <= '9'

    思路

    双指针 left, right

    java代码:

    class Solution {
        public int longestSemiRepetitiveSubstring(String S) {
            var s = S.toCharArray();
            int ans = 1, left = 0, same = 0, n = s.length;
            for (int right = 1; right < n; right++) {
                if (s[right] == s[right - 1] && ++same > 1) {
                    for (left++; s[left] != s[left - 1]; left++);
                    same = 1;
                }
                ans = Math.max(ans, right - left + 1);
            }
            return ans;
        }
    }
    
    

    相关文章

      网友评论

          本文标题:【算法题】2730. 找到最长的半重复子字符串

          本文链接:https://www.haomeiwen.com/subject/yvlxudtx.html