c语音写一个判断素数的函数,在主函数输入一个整数,输出是否为素数的信息
时间: 2023-06-14 20:08:31 浏览: 85
以下是用 C 语言编写的判断素数的函数及主函数:
```c
#include <stdio.h>
int is_prime(int num) {
int i;
if (num <= 1) {
return 0;
}
for (i = 2; i <= num / 2; i++) {
if (num % i == 0) {
return 0;
}
}
return 1;
}
int main() {
int num;
printf("请输入一个整数:");
scanf("%d", &num);
if (is_prime(num)) {
printf("%d是素数。\n", num);
}
else {
printf("%d不是素数。\n", num);
}
return 0;
}
```
在 is_prime 函数中,我们首先判断输入的数是否小于等于 1,因为小于等于 1 的数都不是素数。然后从 2 开始循环到 num/2,如果 num 能被 i 整除,则说明 num 不是素数,返回 0;如果循环结束仍然没有找到 num 的因子,则说明 num 是素数,返回 1。
在主函数中,我们首先输入一个整数 num,然后调用 is_prime 函数判断 num 是否为素数,根据函数的返回值输出相应的信息。
相关问题
c语言 写一个判断素数的函数,在主函数输入一个整数,输出是否为素数的信息
好的,以下是一个判断素数的 C 语言函数:
```c
int is_prime(int n) {
if (n <= 1) {
return 0;
}
for (int i = 2; i * i <= n; i++) {
if (n % i == 0) {
return 0;
}
}
return 1;
}
```
接下来在主函数中可以调用这个函数来判断输入的整数是否为素数:
```c
#include <stdio.h>
int is_prime(int n);
int main() {
int n;
printf("请输入一个整数:");
scanf("%d", &n);
if (is_prime(n)) {
printf("%d 是素数\n", n);
} else {
printf("%d 不是素数\n", n);
}
return 0;
}
```
当然,也可以将判断素数的函数写在主函数中,就不需要函数调用了。
编写一个函数用于判断素数,在主函数输入一个整数,输出是否为素数的信息
以下是一个判断素数的函数及其使用示例:
```python
def is_prime(num):
"""
判断一个数是否为素数
"""
if num < 2:
return False
for i in range(2, int(num ** 0.5) + 1):
if num % i == 0:
return False
return True
# 使用示例
n = int(input("请输入一个整数:"))
if is_prime(n):
print(f"{n} 是素数")
else:
print(f"{n} 不是素数")
```
首先,定义了一个函数 `is_prime`,接收一个整数参数 `num`,返回一个布尔值,表示该参数是否为素数。
在函数内部,首先判断参数是否小于 2,因为小于 2 的数都不是素数。然后使用一个循环从 2 开始,到 $\sqrt{n}$ 结束($\sqrt{n}$ 后面的因子一定是前面的因子的倒数),逐个判断是否能被整除,如果能被整除就说明不是素数,返回 False。如果循环结束还没有返回 False,说明是素数,返回 True。
在主函数中,首先使用 `input` 获取用户输入的整数,然后调用 `is_prime` 函数判断该数是否为素数,最后根据函数返回值输出相应的信息。