码迷,mamicode.com
首页 > 其他好文 > 详细

[LeetCode] Plus One

时间:2015-08-14 15:16:01      阅读:93      评论:0      收藏:0      [点我收藏+]

标签:

Given a non-negative number represented as an array of digits, plus one to the number.

The digits are stored such that the most significant digit is at the head of the list.

 

     据说这道题在google的面试中出现频率很高呀。虽然不知道为什么。~

     这道题还是很好思考的。

     比较麻烦的是如果到最开头还是需要继续进位的话就要新建一个长度是原来array长度+1的数组然后将第一个数设为1,后面和原array的一样。

     至于为啥就不说了。应该很好理解的。~

     另外记得要写break,不用进位后计算也就停止了。

     代码如下:

public class Solution {
    public int[] plusOne(int[] digits) {
        int length=digits.length;
        for(int i=length-1;i>=0;i--){
            if(digits[i]==9){
                digits[i]=0;
            }else{
                digits[i]=digits[i]+1;
                break;
            }
            if(i==0&&digits[i]==0){
                int[] temp=new int[digits.length+1];
                temp[0]=1;
                for(int j=1;j<digits.length+1;j++){
                    temp[j]=digits[j-1];
                }
                digits=temp;
                
            }
        }
        return digits;
    }
}

 

[LeetCode] Plus One

标签:

原文地址:http://www.cnblogs.com/orangeme404/p/4729716.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!