m0_56197713 2021-03-17 22:58 采纳率: 100%
浏览 46
已采纳

这个简单的输出100到200的素数的程序哪里错了?

//以下这个无输出结果
int main()
{
	int i = 100, a;
	while (i < 201)
	{
		a = 2;
		while (a < sqrt(i) + 2)
		{
			if (i % a == 0)
			{
				break;
			}

			if (a == sqrt(i) + 1)
			{
				printf("%d,", i);
			}
			a++;

		}
		i++;
	}
	return 0;
}

//以下这个则会输出奇怪的结果
int main()
{
	int i, a;
	for (i=100;i<201;i++)
	{
		for (a = 2; a < sqrt(i) + 2; a++)
		{
			if (i % a == 0)
			{
				printf("%d不是素数", i);
				break;
			}

			if (a==sqrt(i)+1)
			{
				printf("%d是素数,", i);
			}
		}
	}
	return 0;
}

第二种代码的输出结果

纯小白望指教

  • 写回答

3条回答 默认 最新

  • cpp_learners 2021-03-19 09:23
    关注

    我给你改了一下,不用sqrt(i),使用 i / i 的方式:

    	int i, a;
    	for (i = 100; i < 201; i++) {
    		for (a = 2; a < i / i + 2; a++) {
    			if (i % a == 0) {
    				printf("%d不是素数\n", i);
    				break;
    			}
    
    			//printf("sqrt(i) = %d\n", sqrt(i));
    
    			if (a == i / i + 1) {
    				printf("%d是素数\n", i);
    				break;
    			}
    		}
    	}

    一样可以达到效果。

    但是即使是使用sqrt(i) 或者 i / i 的方式,我觉得计算量也都是差不多的啊,也都是要遍历100 - 200中每个数。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 等差数列中的素数个数
  • ¥50 寻找一位有逆向游戏盾sdk 应用程序经验的技术
  • ¥15 请问有用MZmine处理 “Waters SYNAPT G2-Si QTOF质谱仪在MSE模式下采集的非靶向数据” 的分析教程吗
  • ¥50 opencv4nodejs 如何安装
  • ¥15 adb push异常 adb: error: 1409-byte write failed: Invalid argument
  • ¥15 nginx反向代理获取ip,java获取真实ip
  • ¥15 eda:门禁系统设计
  • ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页
  • ¥15 376.1电表主站通信协议下发指令全被否认问题
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证