2301_79725502 2023-09-15 23:59 采纳率: 78.6%
浏览 11
已结题

求素数和与素数的个数

img

img


求个解答为什么这样写代码不对?我这样做出来以后shell显示count和sum都是0

  • 写回答

3条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2023-09-17 01:01
    关注

    【以下回答由 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),这样就避免了多余的除法运算。这样,你的代码应该就能正确计算出素数的个数和和了。


    如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 10月4日
  • 已采纳回答 9月26日
  • 创建了问题 9月15日

悬赏问题

  • ¥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进行服务器的数据共享