C语言 - 判断素数的函数

这篇博客讨论了一个用于判断素数的C语言程序,原始代码存在错误,导致4等非素数被误判为素数。通过分析,修复了程序的逻辑,主要改进包括调整for循环条件为i<=n/2,增加对0和1的判断,并优化了if条件语句,确保当输入的整数能被i整除时,程序正确地将flag设置为0,从而准确判断素数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下列程序写了一个判别素数的函数,在主函数输入一个整数,输出是否为素数的信息。

#include <stdio.h> 
int main()
   {
      int prime(int);
      int n;
      printf("请输入一个整数:");
      scanf("%d",&n);	
     if______________________                 
	     printf("%d 是素数。\n",n);
     else
	     printf("%d 不是素数。\n",n);
     return 0;
   }
  int prime(int n)
  {
     int flag=1,i;
     for(i=2;i<n/2&&flag==1;i++)
     if ______________________                   
     flag=0;
     ________________________;
    }

经分析,以上代码使用flag的值来判断输入的n是否为素数,flag=1,n为素数;flag=0,n不是素数。完善if条件语句,第一个if, 主函数中的if调用函数,需要填入一个参数,即prime(n); 第二个if,是判断什么情况下flag=0,即输入的整数不为素数,即(n/i==0),余数为0,可以整除;最后返回flag的值,return flag。

但是经过运行可以知道,n=4的时候,程序判断4是素数,明显是错误的,n取0和1的时候同理,程序存在漏洞。分析得知,在定义函数的过程中,for循环条件语句,i<=n/2&&flag==1才能正确运行,同时添加if语句对0和1判断。(前提输入的n>=0,如果为负整数,另加判断条件,略)

正确代码如下:

#include <stdio.h> 
int main()
   {
    int prime(int);//函数声明
    int n;
    printf("请输入一个整数:\n");
    scanf("%d",&n);	
    if(prime(n))
	{    
        printf("%d 是素数。\n",n);
    }else
    {
        printf("%d 不是素数。\n",n);
    }
    return 0;
   }
int prime(int n)  //函数定义
{
    int flag = 1,i;
    if (n <= 1)  //判断0和1,需要先排除
       flag = 0; //返回0值
    for(i=2;i <= n/2 && flag == 1;i++) //n无法整除比n/2大的数,flag=1为真,即为素数,继续执行
        if (n%i == 0)                 //如果取余为0,则其可以整除,不是素数。
        flag=0;                     //标记flag=0,非素数。
    return flag;
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值