题目描述:
(1)给定一个由整数组成的非空数组所表示的非负整数,在该数的基础上加一。
(2)最高位数字存放在数组的首位, 数组中每个元素只存储单个数字。
(3)你可以假设除了整数 0 之外,这个整数不会以零开头。
示例 1:
输入: [1,2,3]
输出: [1,2,4]
解释: 输入数组表示数字 123。
示例 2:
输入: [4,3,2,1]
输出: [4,3,2,2]
解释: 输入数组表示数字 4321。
class Solution {
public int[] plusOne(int[] digits) {
int len = digits.length;
for(int i = len - 1; i >= 0; i--) {
digits[i]++;
digits[i] %= 10;
if(digits[i]!=0)
return digits;
}
digits = new int[len + 1];
digits[0] = 1;
return digits;
}
}
class Solution {
public int[] plusOne(int[] digits) {
int len = digits.length;
int index = len - 1;
while (true) {
//指针指向起点且第一个数为9时数组长度需要加1
if (index == 0 && digits[0] == 9) {
digits[0] = 0;
int[] res = new int[len + 1];
res[0] = 1;
System.arraycopy(digits, 0, res, 1, len);
return res;
} else if (digits[index] == 9) {
//向前进位
digits[index] = 0;
index--;
} else {
//最简单的情况:不需要进位
digits[index] = digits[index] + 1;
break;
}
}
return digits;
}
}
这篇博客介绍了如何在给定的整数数组表示的非负数上加一。提供了两种不同的解决方案,一种通过遍历数组从后向前更新,另一种通过判断最高位是否为9来决定是否需要扩展数组。这两种方法都确保了在数组形式下正确地进行加一操作。

790

被折叠的 条评论
为什么被折叠?



