题目
给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。
最高位数字存放在数组的首位, 数组中每个元素只存储单个数字。
你可以假设除了整数 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坚持努力,无惧未来!