求个解答为什么这样写代码不对?我这样做出来以后shell显示count和sum都是0
3条回答 默认 最新
关注 【以下回答由 GPT 生成】
你的代码中的问题在于for循环条件的判断。在计算是否为素数时,你的循环条件是从2开始依次除以i/2,然而这样的条件有些多余。实际上,只需要循环到i的平方根即可判断是否为素数。
下面是修复后的代码:
#include <stdio.h> #include <math.h> int main() { int n, i, count = 0, sum = 0; printf("请输入一个正整数n: "); scanf("%d", &n); for (i = 2; i <= n; i++) { int isPrime = 1; for (int j = 2; j <= sqrt(i); j++) { if (i % j == 0) { isPrime = 0; break; } } if (isPrime) { count++; sum += i; } } printf("素数的个数为:%d\n", count); printf("素数的和为:%d\n", sum); return 0; }
修复后的代码使用sqrt函数来计算平方根,将循环条件改为j <= sqrt(i),这样就避免了多余的除法运算。这样,你的代码应该就能正确计算出素数的个数和和了。
如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥50 代码还没怎么运行但是需要代码功能调用数据
- ¥15 vue请求不到数据,返回状态200,数据为html
- ¥15 访问url时不会自动调用其 Servlet的doGet()
- ¥15 用白鹭引擎开发棋牌游戏的前端为什么这么难找
- ¥35 哪位专业人士知道这是什么原件吗?哪里可以买到?
- ¥15 关于#c##的问题:treenode反序列化后获取不到上一节点和下一节点,Fullpath和Handle报错
- ¥15 一部手机能否同时用不同的app进入不同的直播间?
- ¥20 输入import torch显示Intel MKL FATAL ERROR,系统驱动1%,: Cannot load mkl_intel_thread.dll.
- ¥15 点云密度大则包围盒小
- ¥15 nginx使用nfs进行服务器的数据共享