• 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 };
  • 相关阅读:
    Android开发新手学习总结(六)——android开发目录结构【图文版】
    Android开发新手学习总结(一)——使用Android Studio搭建Android集成开发环境
    62个Android Studio小技巧合集
    Android Studio 入门指南
    Unity操作
    Unity的安装和破解
    pb数据窗口设置操作
    Roll A Ball
    c实现旋转数列
    用循环添加多行、多列视图
  • 原文地址:https://www.cnblogs.com/yocichen/p/10293664.html
Copyright © 2020-2023  润新知