首页 > 其他 > 详细

PAT Rational Sum

时间:2019-04-06 23:57:47      阅读:215      评论:0      收藏:0      [点我收藏+]

Rational Sum (20)

时间限制 1000 ms 内存限制 65536 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小)

题目描述

Given N rational numbers in the form "numerator/denominator", you are supposed to calculate their sum.

输入描述:

Each input file contains one test case. Each case starts with a positive integer N (<=100), followed in the next line N rational numbers "a1/b1 a2/b2 ..." where all the numerators and denominators are in the range of "long int".  If there is a negative number, then the sign must appear in front of the numerator.


输出描述:

For each test case, output the sum in the simplest form "integer numerator/denominator" where "integer" is the integer part of the sum, "numerator" < "denominator", and the numerator and the denominator have no common factor.  You must output only the fractional part if the integer part is 0.

输入例子:

5
2/5 4/15 1/30 -2/60 8/3

输出例子:

3 1/3

#include<iostream>
#include<cstring>
#include<string>
using namespace std;

long long gcd(long long x,long long y){
    return y?gcd(y,x%y):x;
}

long long lcm(long long x,long long y){
    return  x/gcd(x,y)*y;
}

char s[111];

int main(){
    long long a=0,b=1; //a / b
    int n;
    cin >> n;
    while(n--){
        cin >> s;
        char *t = strstr(s,"/");
        if(t) *t =  ;
         
         // a/b + c/d
        long long c,d;
        sscanf(s,"%lld %lld",&c,&d);
        long long aa = a*d + b*c;
        long long bb = b*d;
        long long g = gcd((aa<0)?(-aa):aa,bb);
        a = aa/g;
        b = bb/g;
    }
    long long x = a/b,y = a%b;
    if(y == 0) printf("%lld\n",x);
    else{
        if(x) printf("%lld ",x);
        printf("%lld/%lld\n",y,b);
    }
    return 0;
} 

 

PAT Rational Sum

原文:https://www.cnblogs.com/cunyusup/p/10663460.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!