【66】加一

news/2024/11/13 3:45:05/

题目

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

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

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

我的解题

把digits先转换成str,最终转换成int,然后+1,再转换回去成list。

class Solution:def plusOne(self, digits: List[int]) -> List[int]:numStr=""result=[]for i in digits:numStr=numStr+str(i)numInt=int(numStr)+1numStr=str(numInt)for i in numStr:result.append(int(i))return result

Accepted

  • 111/111 cases passed (24 ms)
  • Your runtime beats 97.23 % of python3 submissions
  • Your memory usage beats 51.93 % of python3 submissions (14.9 MB)

看了评论区后,才知道大部分情况还需要思考整型溢出问题。但是,今天我知道了,python 的int 是长整型,理论上支持无限大的数,不用考虑它的溢出问题。

题解

直接数组上改变

class Solution:def plusOne(self, digits: List[int]) -> List[int]:fp=len(digits)-1if digits[fp]!=9:digits[fp]=digits[fp]+1else:# 定位最后一个是9的位while digits[fp]==9 and fp>=0:fp=fp-1# 把fp后面的都进一为0lens=len(digits)-1-fpzeros=[0]*lensdigits[fp+1:]=zeros# 更改进位+1if fp<0:digits.insert(0,1)else:digits[fp]=digits[fp]+1return digits

Accepted

  • 111/111 cases passed (36 ms)
  • Your runtime beats 33.74 % of python3 submissions
  • Your memory usage beats 9.87 % of python3 submissions (15.1 MB)

总结

直接数组上更改要慢一些,判断条件更多。

学到了:列表切片的赋值,必须要是可迭代的数。若已知长度,和赋值,简单的[0]*10,就可以了。也可以结合numpy,生成一个array,进行赋值。

直接转换类型就行。


http://www.ppmy.cn/news/461837.html

相关文章

从零开始搭建群众权益平台(八)

部署过程将涉及多个步骤&#xff0c;具体取决于你选择的部署方法和目标平台。这里将以部署到云服务器为例&#xff0c;提供一个基本的流程&#xff1a; 1. 获取服务器&#xff1a; 首先&#xff0c;你需要一个服务器。你可以选择各种云服务提供商&#xff0c;如AWS、Google C…

1加7 pro (oneplus7 pro) drivedroid测试

网上盛传UFS 3.0如何快法&#xff08;androbench软件测试结果&#xff09;&#xff0c;顺序读取1000MB/s&#xff0c;顺序写入600MB/s&#xff0c;但涉及到drivedroid这个软件&#xff0c;我们要测试的是USB与电脑连接后的传输速度。 先说明一下&#xff0c;我的手机型号是GM1…

从零开始 Spring Boot 43:DI 注解

从零开始 Spring Boot 43&#xff1a;DI 注解 图源&#xff1a;简书 (jianshu.com) Spring 通过注解实现 DI&#xff08;依赖注入&#xff09;&#xff0c;本文详细讨论这些注解。 Autowired Autowired是 Spring 定义的注解&#xff0c;属于包org.springframework.beans.fac…

Vb+access学生公寓管理系统(论文+系统)

随着电脑的普及与使用,现在的管理也提升了一个档次,渐渐实现了无纸化办公,即从原来的人工记录管理模式转变为电脑一体化管理。高校是科研的阵地,后勤的公寓管理也应该一改传统的人工管理,更加信息化,时代化,节省人力物力,提高效率。基于这一点,开发此学生公寓管理软件…

探索计算机网络的奥秘:网络体系结构之深度解析

探索计算机网络的奥秘&#xff1a;网络体系结构之深度解析 本文以严谨的论述和详细的实例展开探讨计算机网络的核心概念与技术&#xff0c;带领读者深入理解网络体系结构的基本原理。 目录 引言网络体系结构的层次 物理层数据链路层网络层传输层应用层 TCP/IP 协议族OSI 参考模…

【SQL应知应会】分析函数的点点滴滴(二)

欢迎来到爱书不爱输的程序猿的博客, 本博客致力于知识分享&#xff0c;与更多的人进行学习交流 本文收录于SQL应知应会专栏,本专栏主要用于记录对于数据库的一些学习&#xff0c;有基础也有进阶&#xff0c;有MySQL也有Oracle 分析函数的点点滴滴 1.什么是分析函数&#xff1a;…

[进阶]Java:文件字节输出流、文件拷贝、资源释放

文件字节输出流&#xff08;FileOutputStream&#xff09;写数据出去的API 流的关闭和刷新 代码演示如下&#xff1a; ​​​​​​​ public class OutputStreamDemo04 {public static void main(String[] args) throws Exception {//1.创建一个文件字节输出流管道与目标文件…

Schneider Electric EcoStruxure Control Expert 15.3 Crack

Schneider Electric EcoStruxure Control Expert 15.3专为使用施耐德电气的Modicon PLC&#xff08;可编程逻辑控制器&#xff09;的控制和自动化工程师量身定制。它提供了一系列功能和工具&#xff0c;以方便自动化应用程序的开发、部署和维护。 施耐德电气EcoStruxure控制专家…