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。
    

    66. 加一

    概要

    考虑一下进位情况即可,新建一个空数组,长度是传入数组的长度+1,然后给第一个位+1返回此数组即可

    提示

    解析

    解法一

    题的意思只是加一,这意味着它的情况只有两种,末位为9或不为9

    末位为9时加一位时进位为0,如果不出现进位运算时结束循环

    考虑特殊情况99,99999等,手动创建数组填入0

    解法二

    从后往前依次给每个数加一,加一后大于10则对10取余,一直到数组的头部的时候i===0数组头部加入一位1即可

    算法

    /**
     * @param {number[]} digits
     * @return {number[]}
     */
    var plusOne = function(digits) {
      for (let i = digits.length - 1; i >= 0; i--) {
        digits[i]++
        digits[i] = digits[i] % 10
        if (digits[i] !== 0) return digits
      }
      digits = new Array(digits.length + 1)
      for (let i = 1; i < digits.length; i++) {
        digits[i] = 0
      }
      digits[0] = 1
      return digits
      // 解法2
      // for (let i = digits.length - 1; i >= 0; i--) {
      //   digits[i]++
      //   if (digits[i] >= 10) {
      //     digits[i] = digits[i] % 10
      //     if (i === 0) {
      //       digits.unshift(1)
      //       break
      //     }
      //   } else {
      //     break
      //   }
      // }
      // return digits
    };
    

    传入[1,2,3]的运行结果

    [1,2,4]
    

    执行结果

    执行用时 :44 ms, 在所有 javascript 提交中击败了100.00% 的用户
    内存消耗 :33.7 MB, 在所有 javascript 提交中击败了33.81%的用户
    
  • 相关阅读:
    数据结构矩阵问题总结
    数据结构:二维ST表
    mysql--时区表问题(Windows环境下)
    mysql--基本命令
    Django2.0--创建缓存表
    git--基本命令
    阿里云主机--重置系统后的登录问题
    链表中倒数第K个结点
    从尾到头打印链表
    替换空格
  • 原文地址:https://www.cnblogs.com/moshuying/p/11828953.html
Copyright © 2011-2022 走看看