关注
第二题你这个代码如果在自己电脑上,会递归深度超出,所以我把数据范围缩小到1-100了,后面附上测试代码和结果:
import time
import random
import math
from collections import defaultdict
def solution(n,input):
result = 0
dp_dict = defaultdict(int)
dp_dict[1] = 0
input_max = max(input)
for number in range(2,input_max):
if number not in dp_dict:
dp_dict[number] = dp_dict[number-1] + 1
if number + 1 in dp_dict:
dp_dict[number+1] = min(dp_dict[number+1],dp_dict[number]+1)
else:
dp_dict[number+1] = dp_dict[number] + 1
for second in range(2,min(number+1,int(math.sqrt(input_max))+1)):
if number * second > input_max:
break
if number * second in dp_dict:
dp_dict[number*second] = min(dp_dict[number*second], dp_dict[number]+dp_dict[second]+1)
else:
dp_dict[number*second] = dp_dict[number]+dp_dict[second]+1
for number in input:
result += dp_dict[number]
return result
查看原帖
点赞 6
相关推荐
12-18 17:51
浙江大学 Java 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 什么是优秀的实习经历 #
7967次浏览 205人参与
# 担心入职之后被发现很菜怎么办 #
266022次浏览 1131人参与
# 被上班搭子“传染”了哪些习惯 #
5233次浏览 97人参与
# 投格力的你,拿到offer了吗? #
152207次浏览 813人参与
# 工作后,你落下了哪些病根 #
12861次浏览 182人参与
# 作业帮求职进展汇总 #
82611次浏览 543人参与
# 京东美团大战,你怎么看? #
157904次浏览 859人参与
# 实习简历求拷打 #
10795次浏览 142人参与
# 如果今天是你的last day,你会怎么度过? #
58859次浏览 324人参与
# 秋招被挂春招仍然能投的公司 #
6391次浏览 94人参与
# mt对你说过最有启发的一句话 #
34591次浏览 417人参与
# 为了找工作你花了哪些钱? #
74769次浏览 359人参与
# 机械人晒出你的简历 #
146394次浏览 874人参与
# 嵌入式岗知多少 #
62951次浏览 555人参与
# 摸鱼被leader发现了怎么办 #
100351次浏览 640人参与
# 考研失败就一定是坏事吗? #
200601次浏览 1369人参与
# 秋招特别不鸣谢 #
15262次浏览 175人参与
# 2023毕业生求职有问必答 #
218554次浏览 1662人参与
# 选实习,你更看重哪方面? #
13525次浏览 214人参与
# 牛客十周岁生日快乐 #
197764次浏览 1895人参与
