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

LeetCode(66)Plus One

时间:2015-08-18 16:19:01      阅读:129      评论: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.

分析

该题目要求:将一整数按位存储在vector中,对其实现+1操作,返回结果。
是一道简单题目,对存储序列vector中元素,倒序遍历,末位+1,若<10可直接返回,否则,保存进位加之到下一位,循环至最高位。
若此时,进位依然为1,则新建长度增一的vector首位为1,其余为0,返回即可。

AC代码


class Solution {
public:
    vector<int> plusOne(vector<int>& digits) {
        int len = digits.size();

        if (len == 0)
            return digits;

        int carry = 1;
        for (int i = len - 1; i >= 0; --i)
        {
            digits[i] += carry;
            if (digits[i] >= 10)
            {
                digits[i] -= 10;
                carry = 1;
                continue;
            }
            else{
                carry = 0;
                break;
            }
        }

        if (carry == 0)
            return digits;
        else
        {
            vector<int> v;
            v.push_back(1);
            for (int i = 0; i < len; i++)
                v.push_back(0);
            return v;
        }
    }
};

GitHub测试程序源码

LeetCode(66)Plus One

标签:

原文地址:http://blog.csdn.net/fly_yr/article/details/47752855

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