首页 > 其他 > 详细

Lettcode-加一

时间:2020-01-03 22:11:37      阅读:85      评论:0      收藏:0      [点我收藏+]
技术分享图片

题解: 最高位加1 遇9进1,只能为单数不能为

  arr[9,9]  ->[9,10]  错误

   arr [9,9] ->[1,0,0] 正确


解:
class
Solution { public int[] plusOne(int[] digits) { if(digits[digits.length - 1] != 9) { digits[digits.length-1] = digits[digits.length-1] + 1; return digits; } //全部为9整体向前进1 int arr [] = new int[digits.length + 1]; boolean isNew = true ; for(int i = 0 ; i < digits.length; i++) { if(digits[i] != 9) { isNew = false ; } } if(isNew) { for(int i = 0 ; i < digits.length; i++) { arr[i] = 0 ; } arr[0] = 1 ; return arr ; } else { // 补1 int max = digits.length - 1 ; int result = digits[max] + 1; while(true) { if(result == 10) { digits[max] = 0; digits[max - 1 ] = digits[max - 1] + 1; if(digits[max - 1] < 10) { break; } result = digits[max - 1]; } max -- ; } return digits; } } }

Lettcode-加一

原文:https://www.cnblogs.com/1-Admin/p/12147033.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!