zoukankan      html  css  js  c++  java
  • leetcode-66.加一

    leetcode-66.加一

    题意

    给定一个由整数组成的非空数组所表示的非负整数,在该数的基础上加一。

    最高位数字存放在数组的首位, 数组中每个元素只存储一个数字。

    你可以假设除了整数 0 之外,这个整数不会以零开头。

    示例 1:

    输入: [1,2,3]
    输出: [1,2,4]
    解释: 输入数组表示数字 123。
    

    示例 2:

    输入: [4,3,2,1]
    输出: [4,3,2,2]
    解释: 输入数组表示数字 4321。

    示例 3:

    输入: [9,9,9,9]
    输出: [1,0,0,0,0]
    解释: 输入数组表示数字 9999。

    示例 4:

    输入: [9]
    输出: [1,0]
    解释: 输入数组表示数字 9。

    算法

    对数组末尾元素+1,进入模式Pattern

    ···

    如果该元素值大于10,暂存 元素值%10,元素值/10

    元素值%10赋给自己,元素值/10加给前一位/1,索引值--

    如果到达首位,特殊处理:取余值赋给自己,在前面插入新元素(值为1)

    ···

    返回数组

    code

     1 class Solution {
     2 public:
     3     vector<int> plusOne(vector<int>& digits) {
     4         int i = digits.size()-1;
     5         digits[i] += 1;
     6         int thisBit, nextBit;
     7         while(digits[i] >= 10)
     8         {
     9             thisBit = digits[i]%10;
    10             nextBit = digits[i]/10;
    11             if(i == 0)
    12             {
    13                 digits[i] = thisBit;
    14                 digits.insert(digits.begin(), 1);
    15                 break;
    16             }
    17             else
    18             {
    19                 digits[i] = thisBit;
    20                 digits[i-1] += 1;
    21                 i--;
    22             }
    23         }
    24         return digits;
    25     }
    26 };
  • 相关阅读:
    软件开发过程中应当遵守的原则
    企业架构是什么?
    软件工程的精髓
    PHP获取自然周列表,周开始结束日期,月开始结束时间方法类
    JS替换textarea里的回车换行
    PHP连接PGSQL
    PT与PX的区别
    JQuery 翻页小记
    PHP中替换textarea时的回车换行
    HTML5 CanvasOreilly.Canvas.Pocket.Reference (4)
  • 原文地址:https://www.cnblogs.com/yocichen/p/10293664.html
Copyright © 2011-2022 走看看