Skip to content

Latest commit

 

History

History
74 lines (51 loc) · 1.81 KB

54.md

File metadata and controls

74 lines (51 loc) · 1.81 KB

C 程序:检查数字是否为质数

原文: 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) {

} 

如果ni完全整除,则n不是质数。 在这种情况下,flag设置为 1,并使用break语句终止循环。

循环后,如果n为质数,则flag仍为 0。但是,如果n为非质数,则flag将为 1。

访问此页面以了解如何打印两个间隔之间的所有质数。