可以封装一个函数来判断一个数是否为素数,然后在主函数中调用这个函数来判断。
以下是一个示例代码:
#include <stdio.h>
int isPrime(int num) {
// 如果num小于2,直接返回0
if (num < 2) {
return 0;
}
// 遍历2到num-1,判断是否存在num的因子
for (int i = 2; i < num; i++) {
// 如果存在num的因子,则num不是素数,返回0
if (num % i == 0) {
return 0;
}
}
// 如果遍历完2到num-1都没有找到num的因子,说明num是素数,返回1
return 1;
}
int main() {
int num;
printf("请输入一个正整数:");
scanf("%d", &num);
if (isPrime(num)) {
printf("%d是素数。\n", num);
} else {
printf("%d不是素数。\n", num);
}
return 0;
}
在上面的示例代码中,我们定义了一个isPrime
函数,这个函数通过遍历2到num-1来判断num是否有因子,如果有则返回0,表示不是素数;如果没有则返回1,表示是素数。
在主函数中,首先提示用户输入一个正整数,然后调用isPrime
函数判断这个数是否为素数,并输出结果。