【1081】Rational Sum (20 分)

简介: 【1081】Rational Sum (20 分)【1081】Rational Sum (20 分)
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<string.h>
#include<algorithm>  
#include<map>
#include<vector>
#include<queue> 
using namespace std; 
typedef long long ll;  //记ll为long long
ll gcd(ll a,ll b){       //求a与b的最大公约数
  return b==0?a:gcd(b,a%b);
}
struct Fraction{  //分数
  ll up,down;  //分子,分母
};
Fraction reduction(Fraction result){  //化简
  if(result.down <0) {  //分母为负数,令分子和分母都变为相反数
    result.up=-result.up;
    result.down=-result.down;
  }
  if(result.up == 0){       //如果分子为0
    result.down=1;  //令分母为1
  }else{                     //如果分子不为0,进行约分
    int d=gcd(abs(result.up) , abs(result.down));  //分子分母的最大公约数
    result.up /= d;  //约去最大公约数
    result.down /= d;
  }
  return result;
}
Fraction add(Fraction f1,Fraction f2){  //分数f1加上分数f2
  Fraction result;
  result.up=f1.up*f2.down+f2.up*f1.down;    //分数和的分子
  result.down=f1.down *f2.down;  //分数和的分母
  return reduction(result);             //返回结果分数,注意化简
}
void showResult(Fraction r){   //输出分数r
  reduction(r);
  if(r.down == 1) printf("%lld",r.up);  //整数
  else if(abs(r.up) > r.down){               //假分数
    printf("%lld %lld/%lld\n",r.up / r.down, abs(r.up)%r.down , r.down);
  }else{                                   //真分数
    printf("%lld/%lld\n",r.up,r.down);
  }
}
int main(){   
  int n;  //分数个数
  scanf("%d",&n);     //分数个数
  Fraction sum,temp;   
  sum.up=0;sum.down=1 ;//初值:和的分子为0,分母为1!!!
  for(int i=0;i<n;i++){
    scanf("%lld/%lld",&temp.up,&temp.down);
    sum=add(sum,temp);      //sum增加temp
  }
  showResult(sum);  //输出结果
  system("pause");
    return 0;   
}
相关文章
|
11月前
|
机器学习/深度学习
计算sum=1+2...+n,要求number和sum的类型都是int,且sum在32位以内~
计算sum=1+2...+n,要求number和sum的类型都是int,且sum在32位以内~
|
C++
【PAT甲级 - C++题解】1081 Rational Sum
【PAT甲级 - C++题解】1081 Rational Sum
83 0
|
算法
1081. Rational Sum (20)
1081. Rational Sum (20)
111 0
1081. Rational Sum (20)
h0125. 求sum(2) (15 分)
h0125. 求sum(2) (15 分)
55 0
【1088】Rational Arithmetic (20 分)
【1088】Rational Arithmetic (20 分) 【1088】Rational Arithmetic (20 分)
96 0
【1059】Prime Factors (25 分)
【1059】Prime Factors (25 分) 【1059】Prime Factors (25 分)
95 0
【1060】Are They Equal (25分)
【1060】Are They Equal (25分) 【1060】Are They Equal (25分)
85 0
【1048】Find Coins (25 分)
【1048】Find Coins (25 分) 【1048】Find Coins (25 分)
110 0
【1015】Reversible Primes (20 分)
【1015】Reversible Primes (20 分) 【1015】Reversible Primes (20 分)
76 0