原文: https://www.programiz.com/c-programming/examples/prime-number
要理解此示例,您应该了解以下 C 编程主题:
质数是一个只能被1
及其本身整除的正整数。 例如:2、3、5、7、11、13、17
#include <stdio.h>
int main() {
int n, i, flag = 0;
printf("Enter a positive integer: ");
scanf("%d", &n);
for (i = 2; i <= n / 2; ++i) {
// condition for non-prime
if (n % i == 0) {
flag = 1;
break;
}
}
if (n == 1) {
printf("1 is neither prime nor composite.");
}
else {
if (flag == 0)
printf("%d is a prime number.", n);
else
printf("%d is not a prime number.", n);
}
return 0;
}
输出
Enter a positive integer: 29
29 is a prime number.
在程序中,从i = 2
循环到i < n/2
进行for
循环。
在每次迭代中,使用以下命令检查n
是否可被i
完全整除。
if (n % i == 0) {
}
如果n
被i
完全整除,则n
不是质数。 在这种情况下,flag
设置为 1,并使用break
语句终止循环。
循环后,如果n
为质数,则flag
仍为 0。但是,如果n
为非质数,则flag
将为 1。
访问此页面以了解如何打印两个间隔之间的所有质数。