力扣:3101. 交替子数组计数

3101. 交替子数组计数

给你一个二进制数组nums 。如果一个子数组中 不存在 两个 相邻 元素的值 相同 的情况,我们称这样的子数组为 交替子数组

返回数组 nums 中交替子数组的数量。

示例 1:

输入: nums = 0,1,1,1

输出: 5

解释:

以下子数组是交替子数组:[0][1][1][1] 以及 [0,1]

示例 2:

输入: nums = 1,0,1,0

输出: 10

解释:

数组的每个子数组都是交替子数组。可以统计在内的子数组共有 10 个。

提示:

  • 1 <= nums.length <= 105
  • nums[i] 不是 0 就是 1
java 复制代码
class Solution {
    public long countAlternatingSubarrays(int[] nums) {
        long  ans = 1;
        for(int end = 1,start = 0;end <nums.length;end++){
            if(nums[end] == nums[end -1]){
                start = end;
            }
            //如果一个数组为交替
            ans += end - start + 1; //end-start+1计算的是start到end的子数组数量,但是单个只包含end
        }
        return ans;
    }
}
相关推荐
少许极端7 分钟前
算法奇妙屋(五十二)-备战+复习2
java·算法
luj_17687 分钟前
硝酸核关联假说缺乏实验证据
c语言·开发语言·c++·经验分享·算法
fei_sun18 分钟前
【SystemVerilog验证】数据类型(待补充)
数据结构·systemverilog
青梅橘子皮33 分钟前
Linux---虚拟地址空间
linux·运维·算法
无忧.芙桃34 分钟前
数据结构之单链表
c语言·开发语言·数据结构
KaMeidebaby35 分钟前
卡梅德生物技术快报|酵母表达系统工程:裂殖酵母穿梭载体分子改造与载体构建技术总结
网络·人工智能·网络协议·tcp/ip·算法
HZ·湘怡38 分钟前
二叉树 1
数据结构·算法·二叉树·
雨落在了我的手上38 分钟前
Java数据结构(二):时间和空间复杂度
数据结构
悠仁さん1 小时前
list 链式表基本功能模拟实现(双向有头指针循环链表)
c语言·数据结构·链表·list
吴可可1231 小时前
AutoCAD 2024搭配C#开发最佳实践
算法