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;
    }
}
相关推荐
We་ct12 分钟前
LeetCode 12. 整数转罗马数字:从逐位实现到规则复用优化
前端·算法·leetcode·typescript
绿算技术15 分钟前
重塑智算存储范式:绿算技术NVMe-oF芯片解决方案全景剖析
人工智能·算法·gpu算力
sin_hielo27 分钟前
leetcode 3510
数据结构·算法·leetcode
Anastasiozzzz38 分钟前
力扣hot100 20.有效的括号 解析
java·算法·面试·力扣
CrazyClaz43 分钟前
负载均衡算法
算法·负载均衡
嵌入式小能手1 小时前
飞凌嵌入式ElfBoard-系统信息与资源之休眠
c语言·开发语言·算法
历程里程碑1 小时前
哈希3 : 最长连续序列
java·数据结构·c++·python·算法·leetcode·tornado
闻缺陷则喜何志丹1 小时前
【图论】P9661 [ICPC 2021 Macao R] Sandpile on Clique|普及+
c++·算法·图论·洛谷
2401_841495641 小时前
【LeetCode刷题】两两交换链表中的节点
数据结构·python·算法·leetcode·链表·指针·迭代法
傻啦嘿哟2 小时前
构建命令行单词记忆工具:JSON词库与复习算法的完美结合
算法·json