携手创作,共同成长!这是我参与「掘金日新计划 · 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坚持努力,无惧未来!