leetcode 非空数组加一

题目:

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

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

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

示例 1:

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

示例 2:

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

解题思路:

如果数组的最后一位不是9,则直接+1即可。但是如果最后一位是数字9,比如99,999,9999之类,这样的话+1会进一,数组长度也会增加,变成100,1000等;
可以使用循环从后往前看,判断当前数组的元素是数字9的情况。如果不是9,直接加1并且返回数组;如果是9的话让当前位直接变成0,接着继续循环判断9的情况。
如果数组元素全部都是9,像[9,9,9,9]这种情况,我们可以建立一个新数组,新数组的长度要比输入的数组长度大一位,且第一位是1,后面都是0。
concat() 方法用于合并两个或多个数组。此方法不会更改现有数组,而是返回一个新数组。

var plusOne = function(digits) {
    let len = digits.length;
    
    for(let i=len-1; i>=0; i--) {
        if(digits[i]==9) {
           digits[i] = 0;
        }else {
            digits[i]++;
            return digits;
        }
    }
    
    let newDigits = [1].concat(digits);
    return newDigits;
};

猜你喜欢

转载自blog.csdn.net/xiaojuziliu/article/details/106039553