zoukankan      html  css  js  c++  java
  • 7-33 有理数加法

    7-33 有理数加法(15 分)

    本题要求编写程序,计算两个有理数的和。

    输入格式:

    输入在一行中按照a1/b1 a2/b2的格式给出两个分数形式的有理数,其中分子和分母全是整形范围内的正整数。

    输出格式:

    在一行中按照a/b的格式输出两个有理数的和。注意必须是该有理数的最简分数形式,若分母为1,则只输出分子。

    输入样例1:

    1/3 1/6
    

    输出样例1:

    1/2
    

    输入样例2:

    4/3 2/3
    

    输出样例2:

    2
    思路:先将两个分式通分化成分母一样的分式,然后进行约分,再判断分母是否为1后分别输出。
    #include<stdio.h>
    #include<string>
    #include<stack>
    #include<iostream>
    using namespace std;
    int main()
    {
        int a1, b1, a2, b2;
        scanf("%d/%d %d/%d", &a1, &b1, &a2, &b2);
    
        int a = a1*b2 + a2*b1;                    //进行通分操作
        int b = b1*b2;
    
        if (a == b){ cout << 1 << endl; return 0; }        //如果分子分母相同直接进行输出
    
        int flag = a > b ? b : a;                        //寻找分子分母中较小值,最大公约数一定比较小值要小
    
        for (int i = flag; i >= 1; i--)
            if (a%i == 0 && b%i == 0)                //寻找最大公约数
            {
                a /= i; b /= i; break;
            }
            if (b == 1)
                cout << a << endl;
            else printf("%d/%d
    ", a, b);
        return 0;
    }
     
  • 相关阅读:
    FusionCharts的类
    FusionCharts图表控件中文版使用手册
    java Integer
    java --final关键字
    HTTP缓存机制及原理
    java颜色代码对照表
    centos svn 服务器间的数据迁移
    tp3.2 URL_MODEL为2 配置
    order by group by
    jpgraph 折线图--解决中文乱码的问题(标题和图例)
  • 原文地址:https://www.cnblogs.com/zengguoqiang/p/8337303.html
Copyright © 2011-2022 走看看