题目
题解
代码
public class code66 {
public static int[] plusOne(int[] digits) {
for (int i = digits.length - 1; i >= 0; i--) {
digits[i]++; // 末尾加一
digits[i] %= 10; // 判断是否末尾是9,如果是的话,需要进位操作
if (digits[i] != 0) { // 如果不是9,那么直接简单的加一就可以返回数组了
return digits;
}
} // 如果末位是9,那么就循环,往前一位继续加一,直到遇到不是9的那一位
digits = new int[digits.length + 1]; // 如果该数组所有位都是9
digits[0] = 1; // 那么只需要将该数组初始化为新的数组,长度加一
return digits; // 并把零号元素初始化为一,其他元素会默认初始化为0
}
public static void main(String[] args) {
// int digits[] = { 1, 2, 3 };
// int digits[] = { 4, 9, 9 };
// int digits[] = { 9, 9, 9 };
int digits[] = { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
int res[] = plusOne(digits);
for (int i = 0; i < res.length; i++) {
System.out.print(res[i] + " ");
}
System.out.println();
}
}