博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[LeetCode] Plus One 加一运算
阅读量:6469 次
发布时间:2019-06-23

本文共 2213 字,大约阅读时间需要 7 分钟。

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,那么则会有进位问题,而如果前面位上的数字仍为9,则需要继续向前进位。具体算法如下:首先判断最后一位是否为9,若不是,直接加一返回,若是,则该位赋0,再继续查前一位,同样的方法,知道查完第一位。如果第一位原本为9,加一后会产生新的一位,那么最后要做的是,查运算完的第一位是否为0,如果是,则在最前头加一个1。代码如下:

 

C++ 解法一:

class Solution {public:    vector
plusOne(vector
&digits) { int n = digits.size(); for (int i = n - 1; i >= 0; --i) { if (digits[i] == 9) digits[i] = 0; else { digits[i] += 1; return digits; } } if (digits.front() == 0) digits.insert(digits.begin(), 1); return digits; }};

 

Java 解法一:

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

 

我们也可以使用跟之前那道类似的做法,我们将carry初始化为1,然后相当于digits加了一个0,处理方法跟之前那道题一样,参见代码如下:

 

C++ 解法二 :

class Solution {public:    vector
plusOne(vector
& digits) { if (digits.empty()) return digits; int carry = 1, n = digits.size(); for (int i = n - 1; i >= 0; --i) { if (carry == 0) return digits; int sum = digits[i] + carry; digits[i] = sum % 10; carry = sum / 10; } if (carry == 1) digits.insert(digits.begin(), 1); return digits; }};

 

Java 解法二 :

public class Solution {    public int[] plusOne(int[] digits) {        if (digits.length == 0) return digits;        int carry = 1, n = digits.length;        for (int i = digits.length - 1; i >= 0; --i) {            if (carry == 0) return digits;            int sum = digits[i] + carry;            digits[i] = sum % 10;            carry = sum / 10;        }        int[] res = new int[n + 1];        res[0] = 1;        return carry == 0 ? digits : res;    }}

 

类似题目:

 

参考资料:

 

转载地址:http://lrdko.baihongyu.com/

你可能感兴趣的文章
垃圾收集器与内存分配策略(六)之内存分配与回收策略
查看>>
Ubuntu16.04之编译OpenJDK7源代码(记第一篇)
查看>>
Mybatis批量增加,删除,更新Oracle
查看>>
搞懂VMware和Windows的网络连接
查看>>
Resharper6.0如何启用原VS的中文智能提示
查看>>
【七夕专题】七夕不做单身汪
查看>>
android嵌入lua
查看>>
EZ430 Chronos 自带程序源码:用户函数示范程序
查看>>
ITK VKT 安装-详细
查看>>
jsonrpc-4j代码解析
查看>>
java RunTime 类
查看>>
Log4j使用总结
查看>>
js模拟点击事件实现代码
查看>>
6 亿推送数据告诉你,我们的一天究竟在干嘛
查看>>
android 模拟器对应键盘快捷键
查看>>
SlickEdit 中 GDB 调试时SIG32 使得无法跟踪的问题 解决方法
查看>>
C语言输入数字显示位数,逆序显示,可负数。
查看>>
Hadoop CDH3u6 配置文件
查看>>
Windows VS. Mac 之 屏幕
查看>>
git push warning: push.default is unset;
查看>>