C++学习笔记08:求质数

C++循环结构求质数
本文通过三种不同的循环结构:for、while和do-while,详细展示了如何使用C++编程语言找出1到100之间的所有质数。每种循环都有其独特的应用方式和优势,文章深入解析了它们在解决同一问题时的代码实现差异。

使用三种循环结构,求出1-100的质数。

for循环

#include <iostream>
using namespace std;
int main()
{
	int flag = 0, i, j;
	for (i = 2; i < =100; i++)
	{
		flag = 1;
		for (j = 2; j < i;j++)
			if (i % j == 0) flag = 0;
		if (flag) cout << i << "为质数" << endl;
	}
	return 0;
}

另一种方法

#include <iostream>
using namespace std;
int main()
{
	int j,i;
	for (i = 2; i <= 100; i++)
	{ 
		for (j = 2; j <i; j++)
		{
			if (i % j == 0) break;
		}
		if (i == j)cout << i << endl;
	}
	return 0;
}

while循环结构

#include <iostream>
using namespace std;
int main()
{
	int i=2, j=1, flag=1;
	while (i <= 100)
	{
		j = 2;
		flag = 1;
		while (i>j)
		{
			if (i % j == 0)
			{ 
				flag = 0;
				break;
			}
			j++;
		}
		if (flag) cout << i << "为质数" << endl;
		i++;
	}
	return 0;
}

do while 结构

#include <iostream>
#include <cmath>
using namespace std;
int main()
{
	int i=2, j, flag,k=0;
	do 
	{
		j = 2;
		flag = 1;
		k = sqrt(i);
		do 
		{
			if (i % j == 0&&i!=j) { flag = 0; break; }
			j++;
		} while (j<=k);
		if (flag) cout << i <<"为质数"<< endl;
		i++;
		} while (i <= 100);
	return 0;
}

思考

  1. 使用三种循环结构处理同一个问题,要区分三种语句的格式。
  2. do while结构 循环体内的内容至少被执行一次,所以代码的内容会与另外两种有所不同,主要区别是在条件判断上要稍作改动。
  3. 答案中用到了sqrt函数,使用开方后的数作为除数,可以省去多余的运算,节约程序运行的空间和加快运行速度。
  4. break也起到了类似的作用,一旦发现当前i不满足质数,则不进行多余运算,立刻跳出当前循环。值得注意的是for循环跳出后,不再执行表达式3的内容。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值