鱼C论坛

 找回密码
 立即注册
查看: 1699|回复: 11

[已解决][详情入内]提交结果不理想,有更好的写法吗

[复制链接]
发表于 2022-5-17 13:51:11 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. '''
  2.     题目:
  3.         示例1:
  4.             输入:digits = [1,2,3]
  5.             输出:[1,2,4]
  6.             解释:输入数组表示数字 123。
  7.         示例2:
  8.             输入:digits = [4,3,2,1]
  9.             输出:[4,3,2,2]
  10.             解释:输入数组表示数字 4321。
  11.         示例 3:
  12.             输入:digits = [0]
  13.             输出:[1]
  14.        提示:

  15.             1 <= digits.length <= 100
  16.             0 <= digits[i] <= 9
  17. '''
  18. #我的答案
  19. def plusOne(self, digits: list[int]) -> list[int]:
  20.         k=0
  21.         b=0
  22.         for x in digits[::-1]:
  23.             k+=x*10**b
  24.             b+=1
  25.         return list(map(int,list(str(k+1))))  

  26. #我的提交结果
  27. '''
  28.     执行结果:通过
  29.     执行用时:32 ms, 在所有 Python3 提交中击败了89.59%的用户
  30.     内存消耗:14.9 MB, 在所有 Python3 提交中击败了36.59%的用户

  31.     通过测试用例:
  32.     111 / 111
  33. '''
复制代码
最佳答案
2022-5-17 15:03:37
wp231957 发表于 2022-5-17 14:52
执行结果:
解答错误


试试直接 eval 哈哈:

  1. def plusOne(self, digits: List[int]) -> List[int]:
  2.     num = eval("".join(list(map(str, digits))) + "+1")
  3.     return list(map(int, str(num)))
复制代码


小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-5-17 14:06:48 | 显示全部楼层


题目是什么,原谅我没看懂示例

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-5-17 14:19:58 From FishC Mobile | 显示全部楼层
Twilight6 发表于 2022-5-17 14:06
题目是什么,原谅我没看懂示例

把列表组成一个数字,然后加1  然后再拆分一个列表
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-5-17 14:24:36 From FishC Mobile | 显示全部楼层
89.59% 已经非常高了啊~
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-5-17 14:26:25 From FishC Mobile | 显示全部楼层
傻眼貓咪 发表于 2022-5-17 14:24
89.59% 已经非常高了啊~

内存那个低啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-5-17 14:28:24 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-5-17 14:37:49 From FishC Mobile | 显示全部楼层
试试这个,空间复杂度:O(n)
  1. def plusOne(digits):
  2.         res = []
  3.         digits[-1] += 1
  4.         a = b = 0
  5.         for n in digits[::-1]:
  6.                 a, b = divmod(n + a, 10)
  7.                 res.append(b)
  8.         return res[::-1]

  9. print(*plusOne([1, 2, 3]))
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-5-17 14:52:24 | 显示全部楼层
傻眼貓咪 发表于 2022-5-17 14:37
试试这个,空间复杂度:O(n)


执行结果:
解答错误

通过测试用例:
107 / 111
输入:
[9]
输出:
[0]
预期结果:
[1,0]
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-5-17 15:03:37 | 显示全部楼层    本楼为最佳答案   
wp231957 发表于 2022-5-17 14:52
执行结果:
解答错误


试试直接 eval 哈哈:

  1. def plusOne(self, digits: List[int]) -> List[int]:
  2.     num = eval("".join(list(map(str, digits))) + "+1")
  3.     return list(map(int, str(num)))
复制代码


小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-5-17 15:06:54 | 显示全部楼层
Twilight6 发表于 2022-5-17 15:03
试试直接 eval 哈哈:

执行用时:
40 ms, 在所有 Python3 提交中击败了42.25%的用户
内存消耗:
14.8 MB, 在所有 Python3 提交中击败了92.88%的用户
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-5-17 15:08:51 | 显示全部楼层
wp231957 发表于 2022-5-17 15:06
执行用时:
40 ms, 在所有 Python3 提交中击败了42.25%的用户
内存消耗:



哈哈 不用追求完美啦,这些每次运行结果都有误差的,你能做出来就很棒啦

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-5-17 15:27:39 From FishC Mobile | 显示全部楼层
本帖最后由 傻眼貓咪 于 2022-5-17 15:31 编辑
wp231957 发表于 2022-5-17 14:52
执行结果:
解答错误



哈哈,少一行,已修改:
  1. def plusOne(digits):
  2.         res = []
  3.         digits[-1] += 1
  4.         a = b = 0
  5.         for n in digits[::-1]:
  6.                 a, b = divmod(n + a, 10)
  7.                 res.append(b)
  8.         if(a): res.append(a)
  9.         return res[::-1]

  10. print(*plusOne([9]))
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-29 05:37

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表