LeetCode 3208. 交替组 II

3208. 交替组 II

【分析】这个是3101. 交替子数组计数的升级版

这里环可以这样处理,最后一个元素只需要看和前面 k - 1个元素的关系即可

为什么是k - 1呢,如果多了的话,比如k个,那这段序列就包括0 - k了,这样就重复计算了

所以把前面的k - 1个元素复制到后面去

这里需要注意是子数组,中间不能断,一旦有重复元素就要重新计数,另外长度必须超过k才行

java 复制代码
class Solution {
    public int numberOfAlternatingGroups(int[] colors, int k) {
        int n = colors.length, m = n + k - 1;
        int[] cols = new int[m];
        for (int i = 0; i < n; i++) cols[i] = colors[i];
        for (int i = 0; i < k - 1; i++) cols[i + n] = colors[i];
        int pre = cols[0];
        int res = 0, t = 1;
        for (int i = 1; i < m; i++) {
            if (pre != cols[i]) {
                t += 1;
                if (t >= k) res += 1;
            } else {
                t = 1;
            }
            pre = cols[i];
        }
        return res;
    }
}
相关推荐
Tisfy14 小时前
LeetCode 3531.统计被覆盖的建筑:最大最小值
算法·leetcode·题解·桶排序
京东零售技术14 小时前
SIGIR 2025 | 基于图同构网络的群体建模在点击率预测中的应用
算法
程序员西西14 小时前
深入剖析 Java 中的 ZGC 机制:原理、优势与实践
java·后端·算法
月明长歌14 小时前
【码道初阶】Leetcode.189 轮转数组:不熟悉ArrayList时踩得坑,被Arraylist初始化骗了?
java·算法·leetcode·职场和发展
卡尔AI工坊14 小时前
万众瞩目的 GPT 5.2,连个火柴人游戏都做不明白?
后端·算法
fantasy_arch14 小时前
leetcode算法-最大乘积子数组
算法·leetcode·职场和发展
dragoooon3414 小时前
[hot100 NO.8~12]
算法
kaikaile199515 小时前
MATLAB计算卫星星下点轨迹
开发语言·算法·matlab
_OP_CHEN15 小时前
【算法基础篇】(三十一)动态规划之基础背包问题:从 01背包到完全背包,带你吃透背包问题的核心逻辑
算法·蓝桥杯·动态规划·背包问题·01背包·完全背包·acm/icpc
长安er15 小时前
LeetCode876/141/142/143 快慢指针应用:链表中间 / 环形 / 重排问题
数据结构·算法·leetcode·链表·双指针·环形链表