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

【LeetCode】Plus One

时间:2014-05-15 04:16:56      阅读:245      评论:0      收藏:0      [点我收藏+]

标签:style   blog   class   code   java   c   

题目

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.

解答

本题考察进位问题,注意当位数只有一位并且为9的情况。用do-while语句,逆序循环检查当前位是否是9,是9的话,并判断是否为第一位,若是第一位,则将数组增长一位,第零位置为1,并拷贝原数组,若不为第一位则该位置0并将下标减一;不为9的话,直接加1,跳出循环,代码如下:

public class Solution {
    public int[] plusOne(int[] digits) {
        int len=digits.length;
        int index=len-1;
        do{
            if(digits[index]==9){
                if(index!=0){
                    digits[index]=0;
                    index--;
                }else{
                    digits[index]=0;        
                    int[] tmp=new int[len+1];
                    tmp[0]=1;
                    for(int i=0;i<len;i++)
                        tmp[i+1]=digits[i];
                    return tmp;
                }
            }else{
                digits[index]+=1;
                break;
            }
        }while(true);
        return digits;
    }
}

---EOF---


【LeetCode】Plus One,布布扣,bubuko.com

【LeetCode】Plus One

标签:style   blog   class   code   java   c   

原文地址:http://blog.csdn.net/navyifanr/article/details/25770831

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