zoukankan      html  css  js  c++  java
  • [LeetCode] Plus One 加一运算

    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<int> plusOne(vector<int> &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;
        }
    }

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

    C++ 解法二 :

    class Solution {
    public:
        vector<int> plusOne(vector<int>& 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;
        }
    }

    类似题目:

    Add Binary

    参考资料:

    https://discuss.leetcode.com/topic/24288/my-simple-java-solution

    LeetCode All in One 题目讲解汇总(持续更新中...)

  • 相关阅读:
    docker save docker load
    Vue 开发线路 资料 汇总
    electron 开发拆坑总结
    mysqldbcopy 数据库复制工具
    用rsync命令删除大文件夹
    linux nc,nmap,telnet ,natstat命令
    搭建云版容器版本 需要的基础软件 安装工具
    phantomjs 前端测试工具
    消息列队 php 基于redis 实现
    部分安卓机器【小米手机】,文字显示不全
  • 原文地址:https://www.cnblogs.com/grandyang/p/4079357.html
Copyright © 2011-2022 走看看