--------------------------------------------------------- 题目: 编写函数,要求计算并输出不超过n的最大的k个素数以及它们的和。注意找到 的k个素数先要保存在数组a中。 输入格式: 输入在一行中给出n(10≤n≤10000)和k(1≤k≤10)的值。 输出格式: 在一行中按下列格式输出: 素数1+素数2+…+素数k=总和值 其中素数按递减顺序输出。若n以内不够k个素数,则按实际个数输出。 输入样例1: 1000 10 输出样例1: 997+991+983+977+971+967+953+947+941+937=9664 输入样例2: 12 6 输出样例2: 11+7+5+3+2=28
时间: 2023-06-03 20:05:09 浏览: 72
以下是 Python3 代码实现:
```python
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, k = map(int, input().split())
cnt, i = 0, n
ans = []
while cnt < k and i >= 2:
if is_prime(i):
ans.append(i)
cnt += 1
i -= 1
print(' '.join(str(x) for x in ans) + '=' + str(sum(ans)))
```
思路:
- 首先定义一个函数 `is_prime` 判断一个数是否为素数;
- 从 n 开始倒序遍历,对于每个数,如果是素数就加入答案数组 ans,并令 cnt 计数器加一;
- 直到 cnt 等于 k 或者遍历到 2;
- 输出答案数组和它们的和。
阅读全文