文章目录
- 力扣66. 加一
- 示例
- 代码实现
- 总结收获
力扣66. 加一

示例


代码实现
class Solution {
    public int[] plusOne(int[] digits) {
        int n=digits.length;
        for(int i=n-1;i>=0;i--){
            if(digits[i]!=9){
                digits[i]++;
                for(int j=i+1;j<n;j++){
                    digits[j]=0;
                }
                return digits;
            }
        }
        int[] res=new int[n+1];
        res[0]=1;
        return res;
    }
}
总结收获
-  让我看看有多少人是想着是通过先把原数组转换为一个数,加1后在转成数组!这样是不行的,会溢出,开long long也不够! 
-  事实上,最终我们只需要对数组 digits 进行一次逆序遍历,找出第一个不为 9 的元素,将其加一并将后续所有元素置零即可。如果 digits中所有的元素均为 999,我们需要返回一个新的数组即可。以上就可以涵盖了所有的情况了。 

















![buuctf [极客大挑战 2019]Havefun1](https://img-blog.csdnimg.cn/bf054aab036c4912998ccc5ba1fa4f10.png)

