广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言中如何判断质数
  • 478
分享到

C语言中如何判断质数

C语言判断质数C语言判断C语言质数 2023-03-03 11:03:51 478人浏览 八月长安
摘要

目录C语言判断质数C语言判断素数的函数正确代码如下总结C语言判断质数 写判断质数的程序时,需特别注意边界条件: 1.开始边界条件:2作为第一位质数,不参与循环; 2.循环主体:div

C语言判断质数

写判断质数的程序时,需特别注意边界条件:

1.开始边界条件:2作为第一位质数,不参与循环;

2.循环主体:divisor += divisor % 2 +1代表当除数divisor是奇数时+2,是偶数时+1;

3.结束边界条件:当divisor趋近n时,即divisor=n-1或divisor=n-2,仍然没有数能被n整除,那么可以判断n为质数

#include <stdio.h>
int main() {
    int divisor;
    int n;
    scanf("%d",&n); // 输入要判断的数
    if (n == 2) {
        printf("YES"); 
    } else {
        for (divisor = 2; divisor < n; divisor += (divisor % 2 + 1) ) {
            if (n % divisor == 0) {
                printf("NO"); // 当出现能被1或自身之外整除时
                break;
            } else if (divisor == n - 1 || divisor == n-2) {
                printf("YES"); // 循环到 n-1 或 n-2 时,仍然没有被其他数整除
            }
        }
    }
    return 0;
}

C语言判断素数的函数

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

#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;
}

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: C语言中如何判断质数

本文链接: https://www.lsjlt.com/news/198339.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C语言中如何判断质数
    目录C语言判断质数C语言判断素数的函数正确代码如下总结C语言判断质数 写判断质数的程序时,需特别注意边界条件: 1.开始边界条件:2作为第一位质数,不参与循环; 2.循环主体:div...
    99+
    2023-03-03
    C语言判断质数 C语言判断 C语言质数
  • C语言中怎么判断质数
    这篇文章主要介绍了C语言中怎么判断质数的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言中怎么判断质数文章都会有所收获,下面我们一起来看看吧。C语言判断质数写判断质数的程序时,需特别注意边界条件:开始边界条件...
    99+
    2023-07-05
  • c语言质数判断的方法有哪些
    C语言质数判断的方法主要有以下几种:1. 穷举法:对于给定的数n,从2开始逐个判断n是否能被2到n-1之间的数整除,如果存在能整除的数,则n不是质数;如果不存在能整除的数,则n是质数。2. 埃氏筛法:先将2到n之间的所有数标记为质数,然...
    99+
    2023-08-11
    c语言
  • c语言如何判断位数
    判断一个数字的位数,可以使用循环结构和除法运算来实现。 以下是一个判断位数的示例代码: #include int main() ...
    99+
    2023-10-23
    c语言
  • C语言之素数(质数)的判断以及输出
    目录C素数(质数)的判断及输出一:质数的判断二:输出100~200之间的全部素数总结  C素数(质数)的判断及输出 一:质数的判断 输入一个大于3的整数,判断它是...
    99+
    2023-03-03
    C语言素数 C语言质数 C语言素数的判断 C语言质数的判断
  • c语言如何判断奇偶数
    判断一个数是否为奇数或偶数可以使用取余操作。如果一个数除以2的余数为0,则该数为偶数,否则为奇数。具体代码如下:```c#inclu...
    99+
    2023-09-28
    c语言
  • C语言中如何实现判断
    本篇内容主要讲解“C语言中如何实现判断”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言中如何实现判断”吧!(一)先动手编写一个程序:#include <stdio.h>...
    99+
    2023-06-17
  • c语言怎么判断素数
    判断一个数是否为素数,可以通过以下方法实现:1. 如果给定的数小于2,则它不是素数。2. 对于大于等于2的数,从2到其平方根之间的所有数,依次判断该数是否能被这些数整除。- 如果能被整除,则它不是素数,返回false。- 如果不能被整除...
    99+
    2023-08-11
    c语言
  • C语言中如何判断utf8编码
    本文小编为大家详细介绍“C语言中如何判断utf8编码”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言中如何判断utf8编码”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。实例代码:int utf8_...
    99+
    2023-06-17
  • 用c语言编程实现素数判断(判断素数的c语言程序函数)
    以下是一个用C语言编写的判断素数的函数:```c#include #include bool isPrime(int n) {if ...
    99+
    2023-09-22
    c语言
  • C语言怎么判断奇偶数
    本文小编为大家详细介绍“C语言怎么判断奇偶数”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言怎么判断奇偶数”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。奇偶数判断其实有个更简单高效的办法,我们的整数,在计算...
    99+
    2023-06-17
  • c语言中如何用if判断字符
    在C语言中,可以使用以下方式使用if语句来判断字符:c#include int main() {char c;printf("请输入...
    99+
    2023-10-20
    c语言
  • c语言如何判断奇偶数并输出
    判断奇偶数的方法是通过对该数与2进行取余操作,如果结果为0,则为偶数;如果结果为1,则为奇数。下面是一个示例代码: #include...
    99+
    2023-10-23
    c语言
  • c语言如何判断数组是否为空
    在C语言中,可以通过判断数组的长度来确定数组是否为空。如果数组的长度为0,则表示数组为空。 下面是一个示例代码: #include ...
    99+
    2023-10-24
    c语言
  • c语言如何判断一个数是否在数组中
    在C语言中,可以使用循环结构和条件判断语句来判断一个数是否在数组中。具体步骤如下:1. 声明一个数组,并给数组赋值。2. 声明一个变...
    99+
    2023-10-10
    c语言
  • c语言中怎么判断闰年
    在C语言中,可以使用以下方法判断闰年:1. 若该年份能被4整除但不能被100整除,则为闰年;2. 若该年份能被400整除,则为闰年;...
    99+
    2023-09-11
    c语言
  • c语言怎么判断数组长度
    在C语言中,可以使用sizeof运算符来判断数组的长度。sizeof运算符可以返回一个对象或者类型的大小(以字节为单位)。当应用于数...
    99+
    2023-10-09
    c语言
  • c语言怎么循环判断素数
    C语言循环判断素数的一种常见方法是使用嵌套循环。具体步骤如下: 首先,定义一个变量num,用于接收输入的数字。 然后,使用嵌套循环...
    99+
    2023-10-21
    c语言
  • C语言怎么判断奇数或偶数
    这篇“C语言怎么判断奇数或偶数”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C语言怎么判断奇数或偶数”文章吧。以下实例判断用...
    99+
    2023-06-17
  • C语言中的数据整除判断问题
    目录C语言 数据整除判断题目思路C语言 判断是否整除例子C语言 数据整除判断 题目 C语言编程实现——输入一个整数,判断它能否被 3,5,7 整除,并输出以下...
    99+
    2022-11-13
    C语言数据整除判断 数据整除判断 C语言整除判断
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作