力扣(LeetCode) 66: 加一 - 解法思路

问题概述

给定一个由整数数组表示的大整数 digits,将其加一并返回结果数组。

解法 1:简单方法

工作原理

从右到左处理数字。如果数字小于 9,则加一并返回。否则,将其设为 0 并继续。如果所有数字都是 9,则在前面添加新数字:

python 复制代码
class Solution:
    def plusOne(self, digits):
        for i in range(len(digits) - 1, -1, -1):
            if digits[i] < 9:
                digits[i] += 1
                return digits
            else:
                digits[i] = 0
        
        return [1] + digits

复杂度分析

  • 时间复杂度: O(n) - 最坏情况当所有数字都是 9 时需要扫描整个数组
  • 空间复杂度: O(1) - 不包括输出数组,只使用常数额外空间

何时使用

  • 推荐 - 简单高效
  • 处理所有情况,包括进位传播
  • 当不需要进位时提前返回

对比

方法 时间 空间 最佳适用
简单方法 O(n) O(1) 大多数情况,逻辑清晰

总结

关键思路是从右到左处理数字。当数字小于 9 时,可以立即加一并返回(无进位)。当数字是 9 时,将其设为 0 并继续(进位传播)。如果所有数字都是 9,需要在前面添加新数字 [1]。这个解法高效地实现了这一逻辑,时间复杂度为 O(n),空间复杂度为 O(1)。

相关推荐
ZH15455891319 小时前
Flutter for OpenHarmony Python学习助手实战:模块与包管理的实现
python·学习·flutter
不穿格子的程序员9 小时前
从零开始刷算法——贪心篇1:跳跃游戏1 + 跳跃游戏2
算法·游戏·贪心
大江东去浪淘尽千古风流人物9 小时前
【SLAM新范式】几何主导=》几何+学习+语义+高效表示的融合
深度学习·算法·slam
choke23310 小时前
[特殊字符] Python异常处理
开发语言·python
hqyjzsb10 小时前
盲目用AI提效?当心陷入“工具奴”陷阱,效率不增反降
人工智能·学习·职场和发展·创业创新·学习方法·业界资讯·远程工作
铉铉这波能秀10 小时前
LeetCode Hot100数据结构背景知识之列表(List)Python2026新版
数据结构·leetcode·list
重生之我是Java开发战士10 小时前
【优选算法】模拟算法:替换所有的问号,提莫攻击,N字形变换,外观数列,数青蛙
算法
仟濹10 小时前
算法打卡 day1 (2026-02-06 周四) | 算法: DFS | 1_卡码网98 可达路径 | 2_力扣797_所有可能的路径
算法·leetcode·深度优先
yang)10 小时前
欠采样时的相位倒置问题
算法
千寻girling10 小时前
主管:”人家 Node 框架都用 Nest.js 了 , 你怎么还在用 Express ?“
前端·后端·面试