2024-11-20:交替子数组计数。用go语言,给定一个二进制数组 nums, 如果一个子数组中的相邻元素的值都不相同,我们称这个子数组为交替子数组。 请返回数组 nums 中交替子数组的总数。 输

news/2024/12/26 11:09:08/文章来源:https://www.cnblogs.com/moonfdd/p/18556676

2024-11-20:交替子数组计数。用go语言,给定一个二进制数组 nums,

如果一个子数组中的相邻元素的值都不相同,我们称这个子数组为交替子数组。

请返回数组 nums 中交替子数组的总数。

输入: nums = [0,1,1,1]。

输出: 5。

解释:

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

答案2024-11-20:

chatgpt

题目来自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] 作为示例:

  • 处理第一个元素 0cur 增加到 1,res 变为 1(子数组 [0])。

  • 处理第二个元素 1cur 增加到 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),因为使用的变量(rescurpre)都是常数空间,不依赖于输入数组的大小,未使用额外的数据结构进行存储。

Go完整代码如下:

package mainimport ("fmt"
)func countAlternatingSubarrays(nums []int) int64 {var res, cur int64pre := -1for _, a := range nums {if pre != a {cur++} else {cur = 1}pre = ares += 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));
}

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/837308.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

登录对话框

1.粉红(1)显示   (2)格式/**该页面为粉红色皮肤 *//*背景*/ #frame_background{ border-image:url(:/res/pic/background-1.png); }/*登录背景*/ #frame_login{background-color:#ffffff}/*右侧图片*/ #frame_pic{background-image:url(:/res/pic/1.png);} /*账户和密码框…

Windows注册表增加右键多级菜单

前言全局说明一、说明 环境: Windows 11 家庭版 23H2 22631.3737Windows 7 旗舰版二、注册表说明 2.1 项说明 HKEY_CLASSES_ROOT*:系统所有文件,右键系统任一文件都会添加右键菜单 HKEY_CLASSES_ROOT\.txt:在.txt文件,添加右键菜单 HKEY_CLASSES_ROOT\AllFilesystemObjects…

关于使用Pycharm新建flask项目 from flask 红色波浪线解决办法

首先保证 flask已经安装 pip install flask如果依旧报红,依次打开:设置->项目:->项目结构点击 添加内容根 选择当前项目的.venv/Lib/site-packages最后应用保存

Day34--方法的重写

Day34--方法的重写 override 重写 重写是方法的重写,和属性无关 示例: 创建下面三个java文件,并在A.java B.java里面创建方法,Application里面初始化A并引用test方法 ​ A类是B类的子类 package com.liu.oop.demo05;public class A extends B{public static void test…

分享三个选股思路: 元宝底、多维共振、短线金叉

分享三个选股思路: 元宝底、多维共振、短线金叉 作者: 深海游鱼 QQ:396068801 日期:2024年11月 1.元宝底:三条短线快速形成金叉时,是短线追涨买点。 2. 多维共振: 最价金叉+Macd水上金叉,也是短线买点,如果能回踩接人更好。 3. 短线金叉: 三条短期均线聚拢,首日形…

(1)环境准备

前言 暑假趁着打折买的7020,一直到现在(2024年11月20日12:56:06)才打开,然后今天心血来潮准备那驱动啥的都捯饬一下,顺便这几天再看一看有些操作,免得后面用的时候才临时去弄 设备连接 如下图,很方便,直接一根type-c线就搞定了,因为这玩意的下载器直接集成在开发板上了…

SUMO文档阅读——PlainXML

Tutorials https://sumo.dlr.de/docs/Tutorials/index.html net.xml (道路设置) 和 route.xml (车类型设置 + 车流量设置) + .sumocfg (综合前两个xml文件) 十字路口的例子 https://sumo.dlr.de/docs/Networks/PlainXML.html Tools https://sumo.dlr.de/docs/Tools/#tools_by_…

大学减负小技巧

一切仅供学习研究参考。 方法有很多,这里只提供本人认为最方便的手段。 一.脚本刷网课 以Edge浏览器,超星学习通为例 1. 下载脚本管理器,这里使用篡改猴 (Tampermonkey)第二个,下载安装,并固定到工具栏 2.下载合适的脚本,这里推荐这个extension://iikmkjmpaadaobahmlepel…

国产数据库oceanBbase,达梦,金仓与mysql数据库的性能对比 一、比对方法和结果

最近调研了三款国产化数据库与mysql做对比,调研主要性能指标是大数据写入速度、大数据读取速度以及是否支持分表。 一、测试结果 测试结果与预期的差别很大 1、先说oceanBase社区版这款数据库官网上描述性能非常好,感觉可以秒杀mysql,但实际测试结果单节点的情况下,和…

Moebius for SQL Server

Moebius(莫比斯)介绍 Moebius数据库多活集群是格瑞趋势为SQL Server数据库研发的能够同时满足可用性、数据安全、容灾、读写分离、负载均衡的一站式多活集群。集群的名字取自Moebius环,寓意无限扩展。Moebius采用“share nothing”架构,每个节点的SQL Server服务独立安装,…

母亲的回头

写在前面392 字 | 亲情 | 思考 | 陪伴 | 细节 | 情感 | 感触 | 体验 | 时间正文等车。我说,自己一个人就可以了,都等,空耗两个人的时间。母亲不肯。司机迟到了十多分钟。这过程中,母亲很焦急。我上了车。母亲敲了敲司机的车窗。司机将窗摇下来,听见她问收不收现金。司机点…

[68] (NOIP集训) NOIP2024 加赛 5

恐将成为我改题时间最长的一场(也是分最低的一场)码长断崖式领先了 flowchart TBA(暴力操作)style A color:#ffffff,fill:#00c0c0,stroke:#ffffff 首先你肯定要让小于(等于)中位数的数变小,将较大的值变小是毫无意义的,因为即使你完全不管他们,也不会对答案造成任何影响…