当前位置: 首页 > news >正文

3101.力扣每日一题7/6 Java(接近100%解法)

  • 博客主页:音符犹如代码
  • 系列专栏:算法练习
  • 关注博主,后期持续更新系列文章
  • 如果有错误感谢请大家批评指出,及时修改
  • 感谢大家点赞👍收藏⭐评论✍

 

 

目录

思路

解题方法

时间复杂度

空间复杂度

Code 


思路

主要是基于对题目要求的理解和对数组遍历的应用。题目要求计算数组中所有可能的交替子数组的数量,其中交替子数组是指相邻元素不相等的子数组。

解题方法

  1. 初始化:设置两个变量,ans 用于记录所有交替子数组的总数,cnt 用于记录以当前元素结尾的交替子数组的数量。由于每个元素自身至少可以构成一个交替子数组(即使它与前一个元素相同),因此 cnt 初始化为 1。

  2. 遍历数组:从数组的第二个元素开始遍历(因为第一个元素自身就是一个交替子数组,无需比较)。对于每个元素,检查它是否与前一个元素不同。

    • 如果不同,说明可以将前一个交替子数组扩展一个当前元素来形成新的交替子数组,因此 cnt 递增。
    • 如果相同,说明无法将前一个交替子数组扩展,因此 cnt 重置为 1,表示当前元素自身构成一个交替子数组。
  3. 累加结果:在每次迭代中,将 cnt 的值加到 ans 上,因为 cnt 表示了以当前元素结尾的所有交替子数组的数量。

  4. 返回结果:遍历完成后,ans 中存储的就是所有交替子数组的总数,将其返回。

时间复杂度 

时间复杂度是 O(n),其中 n 是数组 nums 的长度。因为我们只需要遍历一次数组即可完成计算,所以时间复杂度与数组的长度成正比。

空间复杂度

空间复杂度是 O(1)。尽管我们使用了几个变量(anscnt 和循环变量 i),但这些变量的数量是固定的,不随输入数组的大小而增加。因此,我们可以认为算法使用的额外空间是常数级别的,即空间复杂度为 O(1)。

Code

class Solution {  public long countAlternatingSubarrays(int[] nums) {  long ans = 0; // 用于累积交替子数组的总数  int cnt = 1;  // 以当前元素结尾的交替子数组的数量(初始化为1,因为每个元素自身都是一个交替子数组)  for (int i = 0; i < nums.length; i++) {  // 如果当前元素与前一个元素不同,则增加以当前元素结尾的交替子数组数量  if (i > 0 && nums[i] != nums[i - 1]) {  cnt++;  } else {  // 如果当前元素与前一个元素相同,则重置以当前元素结尾的交替子数组数量为1  cnt = 1;  }  // 将以当前元素结尾的交替子数组数量加到总数上  ans += cnt;  }  return ans; // 返回所有交替子数组的总数  }  
}

 

One today is worth two tomorrows.  Benjamin Franklin 一个今天抵得上两个明天。——本杰明弗兰克林 

http://www.lryc.cn/news/393071.html

相关文章:

  • virtualbox窗口和win10窗口的切换
  • 卫星轨道平面简单认识
  • IP-Guard定制函数配置说明
  • C++常用类
  • React Hooks --- 分享自己开发中常用的自定义的Hooks (1)
  • uniapp H5页面设置跨域请求
  • 使用myCobot280和OAK-D OpenCV DepthAI摄像头制作一个实时脸部跟踪的手机支架!
  • Xilinx FPGA:vivado关于单端ROM的一个只读小实验
  • 集成学习(一)Bagging
  • Docker 中查看及修改 Redis 容器密码的实用指南
  • CH09_JS的循环控制语句
  • Python实现Mybatis Plus
  • 卷积神经网络和Vision Transformer的对比之归纳偏置
  • Java之网络面试经典题(一)
  • Failed to download metadata for repo ‘docker-ce-stable‘
  • vant拍摄视频上传以及多张图片上传
  • 如何用手机拍出高级感黑白色调照片?华为Pura70系列XMAGE演绎黑白艺术
  • Cartographer前后端梳理
  • Java面试题系列 - 第3天
  • 【Spring Boot】Spring Boot简介
  • Akamai+Noname强强联合 | API安全再加强
  • 第四届BPAA算法大赛成功举办!共研算法未来
  • 2024第三届中国医疗机器人大会第一轮通知
  • 常见算法和Lambda
  • 自动缩放 win7 远程桌面
  • 微机原理与单片机 知识体系梳理
  • 低音炮内存卡格式化后无法播放音乐文件
  • 手动将dingtalk-sdk-java jar包打入maven本地仓库
  • C++:构造函数是什么东西
  • 工作两年后,我如何看待设计模式