进阶PAT 2021-12-12 12:16 采纳率: 78.4%
浏览 104
已结题

使用C++实现简单的分数运算小程序

题目描述:
输入两个分数,要求求得两个分数的和
输入格式:
多行测试样例,第一行输入一个整数N,表示测试样例数
每行包含四个数字,分别表示两分数
格式为:
分子1 分母1 分子2 分母2
输出格式:
输出两个分数相加的最简结果的分子分母,用空格分隔开,如果是整数,分母要求为1
输入样例:
3
1 2 1 3
2 1 3 1
2 4 3 6
输出样例:
5 6
5 1
1 1

  • 写回答

2条回答 默认 最新

  • 南七灵 2021-12-12 12:27
    关注
    
    #include "stdio.h"
    #include <iostream>
    using namespace std;
    
    int main()
    {
        int a, b, c, d, n;
        int x, y;
        cin >> n;
        for (int m = 0; m < n; m++)
        {
            cin >> a >> b >> c >> d;
            x = a * d + b * c;
            y = b * d;
            int i;
            int f = a < b ? a : b;
            for (i = f; i >= 1; i--)
            {
                if (a % i == 0 && b % i == 0)
                    break; //运用定义法求公约数
            }
            int t = i;
            int g = x < y ? x : y;
            int h;
            for (h = g; h >= 1; h--)
            {
                if (x % h == 0 && y % h == 0)
                    break; //再次运用定义法求公约数
            }
            cout << x / h << " " << y / h << endl; //用所求得的公约数化简
        }
    
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 12月12日
  • 已采纳回答 12月12日
  • 创建了问题 12月12日

悬赏问题

  • ¥15 根据以下文字信息,做EA模型图
  • ¥15 删除虚拟显示器驱动 删除所有 Xorg 配置文件 删除显示器缓存文件 重启系统 可是依旧无法退出虚拟显示器
  • ¥15 vscode程序一直报同样的错,如何解决?
  • ¥15 关于使用unity中遇到的问题
  • ¥15 开放世界如何写线性关卡的用例(类似原神)
  • ¥15 关于并联谐振电磁感应加热
  • ¥60 请查询全国几个煤炭大省近十年的煤炭铁路及公路的货物周转量
  • ¥15 请帮我看看我这道c语言题到底漏了哪种情况吧!
  • ¥60 关机时蓝屏并显示KMODE_EXCEPTION_NOT_HANDLED,怎么修?
  • ¥66 如何制作支付宝扫码跳转到发红包界面