题目描述
编写函数,接收一个正偶数作为参数,输出两个素数,要求这两
个素数之和等于该正偶数。如果存在多个组合满足条件,全部输
出,以列表形式输出。
代码如下
import math
def isprime(n):
# 判断是否为素数
flag = True
for i in range(2, int(math.sqrt(n)) + 1):
if n % i == 0:
flag = False
break
return flag
def demo(n):
prime_num_list = [] # 用于存放满足条件的素数
if n > 0 and n % 2 == 0:
for i in range(3, int(n / 2) + 1):
if isprime(i) and isprime(n - i):
# 以元组的形式存放
prime_num_list.append((i, n - i))
print(prime_num_list)
gl_n = int(input("请输入一个正偶数:"))
demo(gl_n)
运行效果
请输入一个正偶数:66
[(5, 61), (7, 59), (13, 53), (19, 47), (23, 43), (29, 37)]