ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

用C语言查找100 ~ 200之间的素数

2022-02-08 14:59:35  阅读:121  来源: 互联网

标签:200 奇数 int 素数 C语言 flag 100


1. 素数与奇数

素数又称质数,不同于奇数。

素数只有 1 和它本身俩个约数。例如: 155 不属于素数

奇数:整数中,不能被 2 整除的数是奇数。例如:155是奇数

2. 打印和存储 100 ~ 200 这 101 个数字

可以利用 for 循环 + 数组的方法

或者是单独利用for循环实现100 ~ 200数字的打印和存储(该种方法效率更高):

这样就要利用 for (i = 100;i < 201;i++) 中的 i 来实现这些数字的打印和存储

3. 求解思路:

因为用 i 来实现100 ~ 200这些数字的存储和使用,所以就是要判断 i 是否为素数

我们要用 2 ~ (i -1)  这些数字去试除以 i

如果 i 被整除,就说明 i 不是素数

如果 2 ~ (i -1) 之间的数字都不能整除 i (这里的都不能是关键),则说明 i 是素数

注意:

这里的难点是:要如何把 2~(i - 1) 之内的所有数都去尝试完,因为只有这样才能证明它是一个素数

其解决的办法是:

创建一个中间变量

4. 代码实现:

#include <stdio.h>
int main()
{
	int i = 0;
	for (i = 100; i < 201; i++)
	{
		int j = 2;
		int flag = 1;  //中间变量
		for (j = 2; j < i - 1; j++) //注意这里是 i-1
		{
			if (i % j == 0)
			{
				flag = 0;
				break; //这里的break是关键,如果执行该语句的话,则会跳出内层循环
			}
			else
			flag = 1;
		}
		if (flag == 1)
			printf("素数为%d\n", i);
	}
	return 0;
}

标签:200,奇数,int,素数,C语言,flag,100
来源: https://blog.csdn.net/m0_64075307/article/details/122823239

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有