【C语言】输出100内素数

文章目录

目录

1.概念理解

2.代码实现

(1)输出100内的素数(易理解)

(2)使用sqrt平方根函数输出


1.概念理解

        素数:又称质数。质数是指在大于1的自然数中,除了1和它本身以外不再有其他因数的自然数。

        因数:指整数a除以整数b(b≠0) 的商正好是整数而没有余数,我们就说b是a的因数。(a%b==0则b为a的因数)

2.代码实现

输出样例

2    3    5    7    11   13   17   19   23   29   31   37   41   43   47   53   59   61   67   71   73   79   83   89   97

方法一:输出100内的素数(易理解)

//输出100内素数
#include<stdio.h>
int main()
{
	int i,j,sign;
	for(i=2;i<=100;i++)//100内数字赋值 
	{
		sign=0;
		for(j=2;j<i;j++)//创建大于1小于自身的因数进行判断 
		{
			if(i%j==0)
			{
				sign=1;
                break;//标记变量若进入该语句则不是素数 
			}	
		}
		if(sign==0)
			printf("%-5d",i); //%-5d表示占5个字段且左对齐(即右补空格) 
	} 
 	return 0;
 }

方法二:使用sqrt平方根函数输出

如果一个数不是素数那么它一定是两个数的乘积。 n = sqrt(n) * sqrt(n),假设n是i*j,那么i和j一定有一个是<= sqrt(n) ,另一个>=sqrt(n),因此只看较小那个除数存不存在就可以判断n是否素数。

//输出100内素数
#include<stdio.h>
#include<math.h>
int main()
{
	int i,j,sign;
	for(i=2;i<=100;i++)//100内数字赋值 
	{
		sign=0;
		for(j=2;j<=sqrt(i);j++)//创建大于1小于自身的因数进行判断 
		{
			if(i%j==0)
			{
				sign=1;
                break;//标记变量若进入该语句则不是素数 
			}	
		}
		if(sign==0)
			printf("%-5d",i); //%-5d表示占5个字段且左对齐(即右补空格) 
	} 
 	return 0;
 }

  • 74
    点赞
  • 272
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 14
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

HimMzi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值