66-Lettcode-加一

Posted 1-admin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了66-Lettcode-加一相关的知识,希望对你有一定的参考价值。

技术图片

题解: 最高位加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; } } }

以上是关于66-Lettcode-加一的主要内容,如果未能解决你的问题,请参考以下文章

导航抽屉backstack,如何让actionbar标题在点击后随片段改变

AngularJS ——ngResourceRESTful APIs 使用

HDU4057 Rescue the Rabbit(AC自动机+状压DP)

求java Date类型字段加一天代码

函数式编程/命令式编程

微信小程序代码片段