令 P i表示第 i 个素数。现任给两个正整数 M≤N≤104
,请输出 PM到 PN 的所有素数。
输入格式:
输入在一行中给出 M 和 N,其间以空格分隔。
输出格式:
输出从 P M到 P N的所有素数,每 10 个数字占 1 行,其间以空格分隔,但行末不得有多余空格。
输入样例:
5 27
输出样例:
11 13 17 19 23 29 31 37 41 43
47 53 59 61 67 71 73 79 83 89
97 101 103
代码:
import math
def is_prime(n):
if n <= 1:
return False
for i in range(2, int(n ** 0.5) + 1):
if n % i == 0:
return False
return True
n,m=[int(x) for x in input().split()]
list_num=[]
cnt=0
for i in range(1,1000100):
if is_prime(i):
list_num.append(i)
cnt+=1
if cnt==m:
break
for i in range(n-1, len(list_num), 10):
line = ' '.join(str(x) for x in list_num[i:i+10])
print(line)
很奇怪的代码,有个样例有时候会通不过