leetcode66:加一

news/2024/12/14 10:20:16/

原题地址:66. 加一 - 力扣(LeetCode)

题目描述

给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。

最高位数字存放在数组的首位, 数组中每个元素只存储单个数字。

你可以假设除了整数 0 之外,这个整数不会以零开头。

示例 1:

输入:digits = [1,2,3]
输出:[1,2,4]
解释:输入数组表示数字 123。

示例 2:

输入:digits = [4,3,2,1]
输出:[4,3,2,2]
解释:输入数组表示数字 4321。

示例 3:

输入:digits = [9]
输出:[1,0]
解释:输入数组表示数字 9。
加 1 得到了 9 + 1 = 10。
因此,结果应该是 [1,0]。

解题思路

题目要求对一个非负整数数组表示的数字加 1,并返回一个新的数组。
这是一个模拟加法操作的题目。主要需要处理两种情况:

  1. 普通情况:直接对最后一位加 1,并根据进位向前处理即可。
  2. 进位到最高位:当最高位有进位时,需要扩展数组长度。

算法思路如下:

  1. 从数组末尾开始遍历,对当前位进行加 1 操作,同时处理进位。
  2. 如果最高位存在进位,则创建一个新的数组,将进位放入最高位。
  3. 返回最终处理后的数组。

源码实现

class Solution {public int[] plusOne(int[] digits) {// 判断输入是否为空if (null == digits) {return digits; // 空输入直接返回}// 初始化进位变量为 0int cary = 0;// 从数组末尾开始遍历for (int i = digits.length - 1; i >= 0; i--) {if (i == digits.length - 1) { // 处理最低位int val = digits[i];digits[i] = (val + cary + 1) % 10; // 当前位加 1 并取余数cary = (val + cary + 1) / 10; // 更新进位} else { // 处理其他位int val = digits[i];digits[i] = (val + cary) % 10; // 加上进位并取余数cary = (val + cary) / 10; // 更新进位}}// 如果最高位还有进位if (cary > 0) {// 创建新数组,长度为原数组长度 + 1int[] temp = new int[digits.length + 1];temp[0] = cary; // 将进位放在最高位for (int i = 0; i < digits.length; i++) {temp[i + 1] = digits[i]; // 将原数组的值复制到新数组}return temp; // 返回新数组}// 没有进位,直接返回原数组return digits;}
}

复杂度分析

时间复杂度
  • 每次加法操作的复杂度为 O(1)O(1),总共需要遍历整个数组,故时间复杂度为:O(n)O(n) 其中 nn 为输入数组的长度。
空间复杂度
  • 如果最高位产生进位,需要额外创建一个长度为 n+1n+1 的新数组,因此空间复杂度为:O(n)O(n)
    • 如果没有进位,则原地修改输入数组,无需额外空间,空间复杂度为 O(1)O(1)。

http://www.ppmy.cn/news/1554992.html

相关文章

Linux中的线程

目录 线程的概念 进程与线程的关系 线程创建 线程终止 线程等待 线程分离 原生线程库 线程局部存储 自己实现线程封装 线程的优缺点 多线程共享与独占资源 线程互斥 互斥锁 自己实现锁的封装 加锁实现互斥的原理 死锁 线程同步 线程的概念 回顾进程相关概念 …

《Django 5 By Example》阅读笔记:p493-p520

《Django 5 By Example》学习第 17 天&#xff0c;p493-p520 总结&#xff0c;总计 28 页。 一、技术总结 1.internationalization(国际化) vs localization(本地化) (1)18n&#xff0c;L10n&#xff0c;g11n 以前总觉得这两个缩写好难记&#xff0c;今天仔细看了下维基百科…

Jmeter如何对UDP协议进行测试?

Jmeter如何对UDP协议进行测试&#xff1f; 1 jmeter-plugins安装2 UDP-Protocol Support安装3 UDP协议测试 1 jmeter-plugins安装 jmeter-plugins是Jmeter的插件管理器&#xff1b;可以组织和管理Jmeter的所有插件&#xff1b;直接进入到如下页面&#xff0c;选择如图的选项进…

【理想汽车中科院】基于模仿学习的端到端自动驾驶数据缩放规律

论文: https://arxiv.org/pdf/2412.02689 项目: https://github.com/ucaszyp/Driving-Scaling-Law 0. 摘要 端到端自动驾驶范式因其可扩展性而最近吸引了大量关注。然而&#xff0c;现有方法受到现实世界数据规模有限的制约&#xff0c;这阻碍了对端到端自动驾驶相关扩展规律…

得物使用AutoMQ构建海量数据处理的新一代可观测性架构

引言 得物作为全球领先的潮流网购社区&#xff0c;日益增长的用户和数据带来了巨大的技术挑战。当前&#xff0c;得物的可观测性平台每天生成数PB级Trace数据和数万亿条Span记录&#xff0c;要求平台具备高效的实时处理能力和低成本的数据存储解决方案。 传统的存算一体架构将…

【蓝桥杯最新板】蓝桥杯嵌入式液晶上实现电子时钟

这几年蓝桥杯比赛比较适合学生技能学习&#xff0c;考虑板子功能&#xff0c;提出完成的任务。 要求在液晶完成如下图效果&#xff1a; 主要是实现液晶显示时钟和数字时钟&#xff0c;具体样式可以依据实际情况微调。 实现过程&#xff1a; 1.需要画圆&#xff08;外圆、内圆…

颜色的基本处理

数码相机能够获取彩色图像&#xff0c;但相机的色彩处理是一个非常复杂的过程&#xff0c;是非常重要的。 此过程生产制造商在细节方面都是不公布的&#xff0c;但是基本的概念是相同的。当相机捕捉一个真实场景时&#xff0c;是怎么还原成人眼所看到的图像呢&#xff1f; 1.R…

k8s中设置annotation的方法总结

k8s中设置annotation的方法总结 annotation是什么 在 Kubernetes 中&#xff0c;Annotations 是一种用于向 Kubernetes 对象附加非标识性元数据的机制。 annotation有什么用 annotation与 Labels 类似&#xff0c;但有一些关键区别和特定用途。 常用于存储与对象相关的配置…