【C语言】之实现质数的判断

/*
 * 文件名:质数判断.c
 * 功能描述:判断一个数是否为质数
 * 编写人:王廷云
*/
#include <stdio.h>

int main(void)
{
    int num;

    fprintf(stdout, "请输入一个正整数:");

    /* 获取并检查用户输入 */
    while (1)
    {
        if (fscanf(stdin, "%d", &num) != 1)  // 检查输入是否为整数
    	{
    	    fprintf(stderr, "输入错误!请重新输入:");
    	    while (getchar() != '\n');       // 去掉多余的非法字符
    	    continue;
    	}
    	else if (num <= 0)                  // 检查输入是否为正数
    	{
    	    fprintf(stderr, "请输入错误!请输入正整数:");
    	    continue;
    	}
    	else
    	    break;
    }

    /* 质数判断
     * 质数:只能被1和本身整除,最小质数为2
    */
#if 1 /* 方法一:定义法 */
    int i;
    for (i = 2; i < num; i++)
    {
        if (num % i == 0)
    	{
    	    break;
    	}
    }
    if (i == num)   // 除了1以外只有自己能整除自己
        fprintf(stdout, "整数%d为质数\n", num);
    else
        fprintf(stdout, "整数%d不是质数\n", num);

#else /* 方法二:计数法 */
    int i;
    int count = 0;
    for (i = 1; i <= num; i++)
    {
        if (num % i == 0)
    	{
    	    count++;    // 统计能够整除自己的个数
    	}
    }
    if (count == 2)     // 只有1和自己两个数可以整除自己
        fprintf(stdout, "整数%d为质数\n", num);
    else
        fprintf(stdout, "整数%d不是质数\n", num);
#endif

    return 0;
}

  • 9
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值