RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1241317
Accepted
kontsev_
kontsev_
Asked:2022-02-08 12:35:37 +0000 UTC2022-02-08 12:35:37 +0000 UTC 2022-02-08 12:35:37 +0000 UTC

求分数之和

  • 772

给出了几个正分数,用空格隔开。计算分数之和(将结果减去最大公约数)

该程序给出了分段错误。错误在哪里?

    #include <stdio.h>             
        #include <stdlib.h>
            int gcd (int a, int b) {
                if (a == b) {
                    return a;
                else if (a > b) {
                    int tmp;
                    a = b;
                    b = tmp;
                }
            return gcd(a, b - a);
        }
        int main () {
            int a, b, sum = 0, pro = 1, n, *num = NULL, *den = NULL, j, tmp;
            scanf ("%d\n", &n);
            num = malloc(n * sizeof(int));
            den = malloc(n * sizeof(int));
                for (int i = 0; i < n; i++) {
                    scanf ("%d/%d\n", &num[i], &den[i]);
                }
                for (int i = 0; i < n; i++) {
                    pro *= den[i];
                    for ((j = 0 && j != i); j < n; j++)
                        tmp = num[i] * den[j];
                    sum += tmp;
                }
                if (gcd (sum, pro) != 1) {
                    sum %= gcd(sum, pro);
                    pro %= gcd(sum, pro);
                }
                printf ("%d/%d", sum, pro);
                free(num);
                free(den);
        }
c
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Harry
    2022-02-08T12:53:33Z2022-02-08T12:53:33Z

    您的代码根本无法编译。如果您更正明显的错误 - 正如您已经被告知的那样,存在未初始化的变量。您处理分数的方式仅适用于非常小的分子和分母值,因为它很快会导致溢出。

    我会这样做,没有任何数组。long long只是为了安全起见,以防您的分数在相乘时溢出。“保护傻瓜”是最简单的,通过assert.

    #include <stdio.h>
    #include <stdlib.h>
    #include <assert.h>
    
    long long gcd(long long m, long long n)
    {
        while(m && n) if (m < n) n %= m; else m %= n;
        return m + n;
    }
    
    int main ()
    {
        int num;
        long long n, d, s, p;
        scanf("%d", &num);
        scanf("%lld/%lld",&s,&p);
        assert(p != 0);
    
        for (int i = 1; i < num; i++)
        {
            scanf("%lld/%lld", &n, &d);
            assert(d != 0);
            s = s*d + n*p;
            p *= d;
            long long g = gcd(s,p);
            s /= g;
            p /= g;
        }
        printf ("%lld/%lld\n", s, p);
    }
    

    工作示例。您可以亲眼看到价值增长的速度有多快......

    以一种好的方式,还需要减少输入分数以防万一:

    long long gcd(long long m, long long n)
    {
        while(m && n) if (m < n) n %= m; else m %= n;
        return m + n;
    }
    
    void reduce(long long* m, long long* n)
    {
        long long g = gcd(*m, *n);
        *m /= g;
        *n /= g;
    }
    
    int main ()
    {
        int num;
        long long n, d, s, p;
        scanf("%d", &num);
        scanf("%lld/%lld",&s,&p);
        reduce(&s,&p);
        assert(p != 0);
    
        for (int i = 1; i < num; i++)
        {
            scanf("%lld/%lld", &n, &d);
            assert(d != 0);
            reduce(&n,&d);
            s = s*d + n*p;
            p *= d;
            reduce(&s,&p);
        }
        printf ("%lld/%lld\n", s, p);
    }
    
    • 1

相关问题

  • free 出于某种原因不会从内存中删除数组

  • 请帮助代码

  • 为什么 masm 对字符串或文本文字太长发誓,为什么在结构中设置 db 或 dw?

  • 如何将数字拆分为位并将其写入 C 中的数组?

  • 如何以给定的角度移动物体?

  • 解决“子集和问题”的时效算法

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    表格填充不起作用

    • 2 个回答
  • Marko Smith

    提示 50/50,有两个,其中一个是正确的

    • 1 个回答
  • Marko Smith

    在 PyQt5 中停止进程

    • 1 个回答
  • Marko Smith

    我的脚本不工作

    • 1 个回答
  • Marko Smith

    在文本文件中写入和读取列表

    • 2 个回答
  • Marko Smith

    如何像屏幕截图中那样并排排列这些块?

    • 1 个回答
  • Marko Smith

    确定文本文件中每一行的字符数

    • 2 个回答
  • Marko Smith

    将接口对象传递给 JAVA 构造函数

    • 1 个回答
  • Marko Smith

    正确更新数据库中的数据

    • 1 个回答
  • Marko Smith

    Python解析不是css

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5