我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python(leetcode)-66加

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

python(leetcode)-66加

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

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

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

示例 1:

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

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

 看到题目觉得非常简单 只需要找到list的最后一个下标位置使其加一 即可。

然而天真如我 下面情况才是这题的重点

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

 需要考虑进位的情况

重新思考:

笔者想到的是先将数组数字转为十进制数字,然后加一,接着按位取模得到每一位的值。

上代码(花费时间48ms)击败70%

 1 import math
 2 class Solution:
 3     def plusOne(self, digits):
 4         """
 5         :type digits: List[int]
 6         :rtype: List[int]
 7         """
 8         a=1
 9         num=0
10         lens=len(digits)
11         for i in range(lens-1,-1,-1):
12             num=num+digits[i]*a
13             a=a*10                     #获得list的十进制数字
14         num=num+1
15 
16         bytes=int(math.log10(num))     #计算数字的位数
17         lens_new=bytes+1
18         result=[]
19 
20         for i in range(lens_new):
21             single=int(num/(10**(bytes-i))) #得到每一位的数字
22             result.append(single)
23             num=num-single*10**(bytes-i)    #将得到的位数减去
24         return result
25 
26 if __name__=="__main__":
27     s=Solution()
28     a=[9,9,9]
29     print(s.plusOne(a))

然后举出比较正常的方法

思路:对每个值遍历判断,如果为9则变为0,并且继续遍历,如果为0到8则加1操作,并且break退出判断

上代码(用时44ms)击败98%

 1 class Solution:
 2     def plusOne(self,digits):
 3         """
 4         :param digits:List[int]
 5         :return:List[int]
 6         """
 7         #
 8         for i in range(1,len(digits)+1): #对每一个值遍历
 9             if(digits[-i]==9):   #如果为9则变为0
10                 digits[-i]=0
11             else:                #如果加1则退出
12                 digits[-i]+=1
13                 break
14         if(digits[0]==0):        #如果全都是9那么第一位为1后面加一个0
15             digits[0]=1          #eg:[9,9,9] --> [1,0,0,0]
16             digits.append(0)
17         return digits
18 if __name__=="__main__":
19     s=Solution()
20     a=[5,9,8]
21     print(s.plusOne(a))

 

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

python(leetcode)-66加

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

python(leetcode)-66加

给定一个由整数组成的非空数组所表示的非负整数,在该数的基础上加一。最高位数字存放在数组的首位, 数组中每个元素只存储一个数字。你可以假设除了整数 0 之外,这个整数不会以零开头。示例 1:输入: [1,2,3]输出: [1,2,4]解释:
2023-01-30

Python 官方文档解读(1):66

Python 解释器 (CPython 3.7)内置有 66 个函数,这些函数在任何时刻都是可用的。此文是为了对这 66 个函数进行简单的梳理,便于以后可能用到它们时能想到。1. abs(x)返回一个数的绝对值。参数x可以是int、floa
2023-01-30

python(leetcode)-283

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。示例:输入: [0,1,0,3,12]输出: [1,3,12,0,0]说明:必须在原数组上操作,不能拷贝额外的数组。尽量减少操作次数。 说下拿到这
2023-01-30

python(leetcode)-344

编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 char[] 的形式给出。不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。你可以假设数组中的所有字符都是 ASCII 码表中
2023-01-30

python(leetcode)-14最

编写一个函数来查找字符串数组中的最长公共前缀。如果不存在公共前缀,返回空字符串 ""。示例 1:输入: ["flower","flow","flight"]输出: "fl"示例 2:输入: ["dog","racecar","car"]输出
2023-01-30

python(leetcode)-1.两

给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。示例:给定 nums = [2, 7,
2023-01-30

python leetcode 字符串相

给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。示例 1:输入: num1 = "2", num2 = "3"输出: "6"示例 2:输入: num1 = "1
2023-01-30

Python Leetcode 字符串中

利用到了python中字典的collections.Counter()函数collections中函数Counter的使用和用法:  counter工具用于支持便捷和快速地计数,  from collections import Count
2023-01-30

LeetCode算法题python解法:

英文题目:The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows like this: (you may want to di
2023-01-30

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录