力扣刷题-加一

71 阅读2分钟

携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第31天,点击查看活动详情

题目

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

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

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

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

题解

我们这里有一个数组,1,2,3,它代表着123这个数字,我们需要做的事情就是让它加一,就变成了124,最后输出数组,1,2,4,加一的情况有两种,如果这个数字不是9的情况,我们就直接加1进行返回,如果是9的情况,我们需要把这个9变成0,在到它的上一位,把它上一位加1,这个也是刚刚的那种情况,需要判断是不是9,其实这里我们也会遇到一个问题,如果当前数组是[9,9,9]的情况,我们这里就需要让它变成[1,0,0,0],我们首先要先想明白,数组它是从左向右的,下标是从0开始的,然后计算的情况下,他是从右往左的,所以我们这里需要用到for循环,倒数获取对应的数字,在循环的过程中需要判断当前数字是不是9,如果不是9则加1,如果是9的情况下,那么就要把当前位置设为0

/**
 * @param {number[]} digits
 * @return {number[]}
 */
var plusOne = function(digits) {
    // 声明循环,进行获取数字
for(let i=digits.length-1;i>=0;i--){
    // 这样的话循环就可以按照倒数进行读取了
    // 判断等不等于9
    if(digits[i]!==9){
        digits[i]++;
        return digits
    }else{
        // 如果是9则置为0
        digits[i]=0;
    }

}
    // 我们之前判断过不等于9,不等于9就可以直接返回了,所以能走到这里的就全是9的情况,全是9的情况下会全是0,所以这里我们使用es6方法进行解构拼接一下
    const result=[1,...digits]
    // 返回结果
    return result

};

j坚持努力,无惧未来!