2024-11-20:交替子数组计数。用go语言,给定一个二进制数组 nums, 如果一个子数组中的相邻元素的值都不相同,我们称这个子数组为交替子数组。 请返回数组 nums 中交替子数组的总数。 输
2024-11-20:交替子数组计数。用go语言,给定一个二进制数组 nums,
如果一个子数组中的相邻元素的值都不相同,我们称这个子数组为交替子数组。
请返回数组 nums 中交替子数组的总数。
输入: nums = [0,1,1,1]。
输出: 5。
解释:
以下子数组是交替子数组:[0] 、[1] 、[1] 、[1] 以及 [0,1] 。
答案2024-11-20:
题目来自leetcode3101。
大体步骤如下:
1.输入数据:首先,我们有一个二进制数组 nums,例如 nums = [0, 1, 1, 1]。我们的目标是计算这个数组中所有交替子数组的数量。
2.交替子数组的定义:交替子数组是指一个子数组中,相邻的元素值必须不同。例如:
2.1.数组 [0] 和 [1] 都是交替子数组,因为它们的元素没有相邻重复的情况。
2.2.数组 [1, 1] 不是交替子数组,因为两个相邻的元素都是 1。
3.初始化变量:
3.1.res:用于存放交替子数组的总数,初始值为 0。
3.2.cur:用于记录当前交替子数组的长度,初始值为 0。
3.3.pre:一个辅助变量,用于保存前一个元素的值,初始设置为 -1(方便与第一个元素进行比较)。
4.遍历数组:
4.1.对于给定的数组 nums 中的每一个元素 a,执行以下操作:
4.1.1.非重复情况:如果当前元素 a 与前一个元素 pre 不相等,表示交替状态继续,故将当前计数 cur 加 1。
4.1.2.重复情况:如果当前元素 a 与前一个元素 pre 相等,则交替状态被破坏,将当前计数 cur 重置为 1,表示当前元素 a 作为新的交替子数组的起始元素。
4.1.3.更新 pre 为当前的元素 a,以便于下一次迭代进行比较。
4.1.4.将当前的 cur 值累加到总数 res 中。这将确保包含所有以当前元素为结束元素的交替子数组。
5.结束遍历:当遍历完整个数组后,res 将包含所有可能的交替子数组的总数。
6.返回结果:最后,函数返回 res,这就是我们需要的交替子数组的数量。
示例分析
以输入 nums = [0, 1, 1, 1] 作为示例:
处理第一个元素
0,cur增加到 1,res变为 1(子数组[0])。处理第二个元素
1,cur增加到 2,res变为 3(包括子数组[1]和[0, 1])。处理接下来的两个元素
1:对于第一个重复
1,由于与前面的pre(也是1)相等,cur重置为 1,res增加到 4(子数组[1])。对于第二个重复
1,同样,cur重置为 1,res增加到 5(再加上[1])。
因此,最后输出结果为 5,包含的交替子数组为
[0]、[1]、[1]、[1]、[0, 1]。
时间复杂度和空间复杂度
时间复杂度:O(n),其中 n 是数组
nums的长度。由于只需对数组遍历一次进行计算,所需的操作量与数组长度成正比。空间复杂度:O(1),因为使用的变量(
res、cur、pre)都是常数空间,不依赖于输入数组的大小,未使用额外的数据结构进行存储。
Go完整代码如下:
package main
import (
"fmt"
)
func countAlternatingSubarrays(nums []int) int64 {
var res, cur int64
pre := -1
for _, a := range nums {
if pre != a {
cur++
} else {
cur = 1
}
pre = a
res += cur
}
return res
}
func main() {
nums := []int{0, 1, 1, 1}
fmt.Println(countAlternatingSubarrays(nums))
}

Rust完整代码如下:
fn count_alternating_subarrays(nums: Vec<i32>) -> i64 {
let mut res = 0;
let mut cur = 0;
let mut pre = -1; // 用于记录前一个值
for &a in &nums {
if pre != a {
cur += 1; // 如果不相同,当前交替子数组长度加1
} else {
cur = 1; // 如果相同,重置为1
}
pre = a;
res += cur; // 累加交替子数组的数量
}
res // 返回结果
}
fn main() {
let nums = vec![0, 1, 1, 1];
println!("{}", count_alternating_subarrays(nums));
}

2024-11-20:交替子数组计数。用go语言,给定一个二进制数组 nums, 如果一个子数组中的相邻元素的值都不相同,我们称这个子数组为交替子数组。 请返回数组 nums 中交替子数组的总数。 输的更多相关文章
- 输出有序数组的中两个元素差值为指定值diff的两个元素
题目: 输出有序数组的中两个元素差值为指定值diff的两个元素. 思路: 这与输出两个元素的和的值为一定值类似,需要两个指针,不同的是:指针不是一左一右,而是一前一后. 如果差值等于diff,则返回: ...
- 遍历查找集合或者数组中的某个元素的值 java代码 详解 Android开发
import java.util.Scanner; public class Test21 { public static void main(String[] args) { //定义并初始化数组 ...
- c语言实践 创建两个包含8个元素的double类型数组,第二个元素的每个元素的值都是对应前一个元素的前n个元素的和
意思就是第二个元素的num[2]等于第一个元素的num[0]+num[1]+num[2] #define COUNT 8 int main(void) { double num1[COUNT]; do ...
- 给定一个double类型的数组arr,其中的元素可正可负可0,返回子数组累乘的最大乘积。例如arr=[-2.5,4,0,3,0.5,8,-1],子数组[3,0.5,8]累乘可以获得最大的乘积12,所以返回12。
分析,是一个dp的题目, 设f[i]表示以i为结尾的最大值,g[i]表示以i结尾的最小值,那么 f[i+1] = max{f[i]*arr[i+1], g[i]*arr[i+1],arr[i+1]} ...
- 给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值target的那两个整数,并返回它们的数组下标。
/** * 给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值target的那两个整数,并返回它们的数组下标. * * 你可以假设每种输入只会对应一个答案.但是,数组中 ...
- JavaScript正则表达式模式匹配(4)——使用exec返回数组、捕获性分组和非捕获性分组、嵌套分组
使用exec返回数组 var pattern=/^[a-z]+\s[0-9]{4}$/; var str='google 2012'; alert(pattern.exec(str)); //返回一个 ...
- php对UTF8字体串进行单字分割返回数组
在网上查了很多字符串分割方法,都无法正确对UTF8字符串进行正确分割返回单个字符的数组.经过对FTU8编码的分析写出了下面的方法对UTF8进行分割.本人测试可用.本方法只支持UTF8编码的,其它编码转 ...
- 【跟着子迟品 underscore】如何优雅地写一个『在数组中寻找指定元素』的方法
Why underscore (觉得这部分眼熟的可以直接跳到下一段了...) 最近开始看 underscore.js 源码,并将 underscore.js 源码解读 放在了我的 2016 计划中. ...
- 让ar执行queryall和queryrow方法返回数组
让ar执行queryall和queryrow方法返回数组 <?phpnamespace common\components;use \CActiveRecord;use \Yii;use \CD ...
- javascript 返回数组中不重复的元素
这是实现结构伪类type-of-type的部分代码: <script type="text/javascript"> var ret= ["span" ...
随机推荐
- .net core下使用事件总线
随着微服务的火热,DDD(领域驱动设计模式)思想风起云涌,冲击着整个软件生态系统.其中,事件总线那是必须知道的了,于是我便抱着一个学习DDD的心态搭建了一个博客网站,目前该网站正在建设 ...
- 使用 crontab 设置 Homebrew 自动更新
本人有强迫症,希望自己电脑上安装的软件永远是最新的.App Store 有自动更新功能,然而 Homebrew 则没有自动更新的选项.每次手动更新的话时间长了又感觉麻烦.后来发现可以使用 cronta ...
- 专业级语义搜索优化:利用 Cohere AI、BGE Re-Ranker 及 Jina Reranker 实现精准结果重排
专业级语义搜索优化:利用 Cohere AI.BGE Re-Ranker 及 Jina Reranker 实现精准结果重排 1. 简介 1.1 RAG 在说重排工具之前,我们要先了解一下 RAG. 检 ...
- 如何在 Nuxt 3 中有效使用 TypeScript
title: 如何在 Nuxt 3 中有效使用 TypeScript date: 2024/9/9 updated: 2024/9/9 author: cmdragon excerpt: 摘要:本文详 ...
- ASP.NET Core – MVC
前言 在 ASP.NET Core – MVC vs Razor Page 里有提到 MVC. 它算是 WebAPI 的抽象. 但是通常 MVC 指的是比较传统的 Website, WebAPI 则是 ...
- Spring —— IoC入门案例
IoC入门案例 思路分析: 1.管理什么?(Service与Dao) 2.如何将被管理的对象告知IoC容器?(配置) 3.被管理的对象交给IoC容器,如何获取到IoC容器? ...
- 系统编程-进程-fork深度理解、vfork简介
1. fork基本使用 #include <unistd.h> #include <stdio.h> int main(){ pid_t pid = fork(); if(pi ...
- Kubernetes基础(基本概念、架构)(十)
一.介绍 Kubernetes(简称 K8S) 的出现是容器化技术发展的必然结果,容器化是应用程序级别的虚拟化,运行单个内核上有多个独立的用户空间实例,这些实例就是容器:容器提供了将应用程序的代码.运 ...
- Linux部署东方通TongWeb7
一.软件版本 操作系统: CentOS 7.5.1804 JDK:1.8_201 东方通:TongWeb7.0.4.2 二.部署流程 2.1 安装JDK 2.1.1 下载JDK并发明回到/opt下解压 ...
- Win11本地部署FaceFusion3最强AI换脸,集成Tensorrt10.4推理加速,让甜品显卡也能发挥生产力
FaceFusion3.0.0大抵是现在最强的AI换脸项目,分享一下如何在Win11系统,基于最新的cuda12.6配合最新的cudnn9.4本地部署FaceFusion3.0.0项目,并且搭配Ten ...