c++ 判断素数 (for语句 / while语句 / do while语句)

c++ 判断素数 (for语句 / while语句 / do while语句)


以判断1000到1100中的素数有哪些为例

1. 利用for语句实现素数的判断

#include "stdafx.h"
#include<iostream>
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
	int i, j, n, m;
	for (i = 1000; i <= 1100; i++)//判断1000到1100中的素数有那些
	{
		m = 1;   //所有值下面对应m=1
		n = i / 2;  //m和n都是实参
		for (j = 2; j <= n; j++)
		if (i % j == 0)
		{
			m = 0;      //i/j的余数为零,即可以整出,此时,m的值改为0,这个数i就不是素数,然后跳出这个循环
			break;
		}
		if (m!=0)  //只有当m不等于0的时候i才是素数 
			cout << i << " ";
	}
	return 0;
}

运行结果如下图所示
运行结果1.0
2. 利用while语句实现素数的判断

#include "stdafx.h"
#include<iostream>;
using namespace std;

int _tmain(int argc, _TCHAR* argv[])
{
	int i, j, n, m;
	i = 1000;
		
	while (i <= 1100)    //while语句是先判断表达式再执行循环语句
	{
		m = 1; n = i / 2;
		j = 2;
		while (j <= n)
		{
			if (i%j == 0)
			{
				m = 0;
				break;
			}
			j++;
		}
		if (m != 0)
			cout << i << " ";
		i++;
	}
	return 0;
}

运行结果如下图所示
运行结果2.0
3. 利用do while语句实现素数的判断

#include "stdafx.h"
#include<iostream>;
using namespace std;


int _tmain(int argc, _TCHAR* argv[])
{
	int i, j, n, m;
	i = 1000;
	do{                              //do...while语句是先执行循环体语句再判断表达式的值
		m = 1; n = i / 2; j = 2;
			do{
				if (i%j == 0)
				{
					m = 0;
					break;
				}
				j++;
			} while (j <= n);
				if (m != 0)
					cout << i << " ";
				i++;
	} while (i <= 1100);
	return 0;
}

运行结果如下图所示
运行结果3.0

  • 3
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值