题解 | #查找组成一个偶数最接近的两个素数#

查找组成一个偶数最接近的两个素数

https://www.nowcoder.com/practice/f8538f9ae3f1484fb137789dec6eedb9?tpId=37&tags=&title=&difficulty=0&judgeStatus=0&rp=1&sourceUrl=%2Fexam%2Foj%2Fta%3FtpId%3D37

# 求出所有素数
n = int(input())
su = []
for i in range(2, n):
    for j in range(2, i//2+1):
        if i % j == 0:
            break
    else:
        su.append(i)
su = sorted(su * 2) # 考虑到类似4=2+2,10=5+5的情况


doubles = []
for i in range(len(su)-1):
    for j in range(i+1, len(su)):
        if su[i] + su[j] == n:
            doubles.append((su[i], su[j]))

diff = []
for i in range(len(doubles)):
    x = abs(doubles[i][0] - doubles[i][1])
    diff.append(x)

Min = diff.index(min(diff))
min_double = doubles[Min]
result = sorted(list(min_double))
for i in result:
    print(i)

全部评论

相关推荐

不愿透露姓名的神秘牛友
11-21 17:16
科大讯飞 算法工程师 28.0k*14.0, 百分之三十是绩效,惯例只发0.9
点赞 评论 收藏
分享
已老实求offer😫:有点像徐坤(没有冒犯的意思哈)
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务