|
Posted on 2013-04-15 11:22 小明 阅读(1370) 评论(3) 编辑 收藏 所属分类: 数据结构和算法
很简单的问题,但是一遍写通过,还是要求基本功比较扎实。注意进位的处理。 Input Output [0] | [1] | | | [1] | [2] | | | [9] | [1,0] | | | [1,0] | [1,1] | | | [9,9] | [1,0,0] | | | [1,2,3] | [1,2,4] | | | [9,9,9] | [1,0,0,0] | | | [8,9,9,9] | [9,0,0,0] | | | [1,0,0,0,0] | [1,0,0,0,1] | | | [9,8,7,6,5,4,3,2,1,0] | [9,8,7,6,5,4,3,2,1,1] | | | 代码如下: public class Solution { public int[] plusOne(int[] digits) { int extra = 1; for(int i=digits.length-1;i>=0;--i){ int t = digits[i]+extra; if(t>=10){ extra = 1; digits[i] = t-10; } else if(extra!=0){ extra = 0; digits[i] = t; break; } } if(extra>0){ int[] newDigits = new int[digits.length+1]; newDigits[0] = extra; System.arraycopy(digits,0,newDigits,1,digits.length); return newDigits; } return digits; } }
评论
in scala: def plusOne(list: List[Int], rem: Int): List[Int] = { val l = list.reverse l match { case x :: xs => x + rem match { case y if y >= 10 => plusOne(xs.reverse, 1) ::: (y % 10) :: Nil case z => plusOne(xs.reverse, 0) ::: z :: Nil } case Nil => Nil } } def main(args: Array[String]): Unit = { val l = List(1, 3, 4, 8, 9, 9) println(plusOne(l, 1)) }
|