文章目录
- 力扣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,我们需要返回一个新的数组即可。以上就可以涵盖了所有的情况了。