素数也成为质数,指的是大于1的整数中,只能被1和这个数本身整除的数。 从键盘输入一系列大于1的正整数,输入1时表示输入结束。 求输入的这些正整数中素数的和。 输入格式: 从键盘输入一系列大于1的正整数,输入1时表示输入结束。 输出格式: 输入的这些正整数中素数的和。c语言
时间: 2024-05-27 08:13:51 浏览: 87
实现如下:
#include <stdio.h>
int is_prime(int num) // 判断一个数是否为素数
{
if (num == 2 || num == 3) {
return 1;
}
if (num == 1 || num % 2 == 0) {
return 0;
}
for (int i = 3; i * i <= num; i += 2) {
if (num % i == 0) {
return 0;
}
}
return 1;
}
int main()
{
int num, sum = 0;
while (1) {
scanf("%d", &num);
if (num == 1) {
break;
}
if (is_prime(num)) {
sum += num;
}
}
printf("%d\n", sum);
return 0;
}
相关问题
素数也成为质数,指的是大于1的整数中,只能被1和这个数本身整除的数。 从键盘输入一系列大于1的正整数,输入1时表示输入结束。 求输入的这些正整数中素数的和。 输入格式: 从键盘输入一系列大于1的正整数,输入1时表示输入结束。 输出格式: 输入的这些正整数中素数的和。
思路:
对于每个输入的正整数,判断是否为素数,如果是则将其加入素数和中。判断素数可以从2到该数的平方根进行遍历,如果能被整除则不是素数。
代码实现:
```python
num = int(input())
prime_sum = 0
while num != 1:
is_prime = True
for i in range(2, int(num ** 0.5) + 1):
if num % i == 0:
is_prime = False
break
if is_prime:
prime_sum += num
num = int(input())
print(prime_sum)
```
编写函数prime,判断一个正整数是否为素数。调用该函数判断从键盘中输入的数是否为素数。素数也称质数,是指只能被1和它本身整除的数。
在编写Python函数`prime(n)`来判断一个正整数n是否为素数时,可以采用试除法,即检查2到n-1之间是否有能整除n的数。如果都没有,则n是素数。以下是代码实现:
```python
def prime(n):
if n <= 1: # 0和1不是素数
return False
elif n == 2: # 2是唯一的偶数素数
return True
elif n % 2 == 0: # 偶数除了2之外都不是素数
return False
else: # 检查奇数因子
for i in range(3, int(n**0.5) + 1, 2): # 只需要检查到n的平方根即可
if n % i == 0:
return False
return True
# 获取用户输入并判断是否为素数
num = int(input("请输入一个正整数:"))
if prime(num):
print(f"{num}是素数")
else:
print(f"{num}不是素数")
阅读全文