import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class test12 {
/**
* 给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。
* 最高位数字存放在数组的首位, 数组中每个元素只存储单个数字。
* 你可以假设除了整数 0 之外,这个整数不会以零开头。
*
* 示例1:
* 输入:digits = [1,2,3]
* 输出:[1,2,4]
* 解释:输入数组表示数字 123。
*
* 示例2:
* 输入:digits = [4,3,2,1]
* 输出:[4,3,2,2]
* 解释:输入数组表示数字 4321。
*
* 示例 3:
* 输入:digits = [0]
* 输出:[1]
*
* 提示:
* 1 <= digits.length <= 100
* 0 <= digits[i] <= 9
* @param args
*/
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
String[] str = br.readLine().split(",");
int[] digits = new int[str.length];
for(int i=0; i< str.length; i++){
digits[i] = Integer.parseInt(str[i]);
}
int[] resDigits = plusOne(digits);
StringBuilder sb = new StringBuilder();
sb.append("[");
for(int i=0; i< resDigits.length-1; i++){
sb.append(resDigits[i]);
sb.append(",");
}
sb.append(resDigits[resDigits.length-1]);
sb.append("]");
System.out.println(sb);
}
public static int[] plusOne(int[] digits){
int len = digits.length-1;
for(int i=len; i>=0; i--){
if(digits[i] != 9){
digits[i]++;
return digits;
}
if(digits[i] ==9 && i == 0){
int[] newDigits = new int[digits.length+1];
newDigits[0]=1;
for(int j=1; j< digits.length+1; j++){
newDigits[j] = 0;
}
return newDigits;
}
digits[i] = 0;
}
return digits;
}
}
05-04
781