PAT:1081. Rational Sum (20) AC(类似math.h中的sqrt(1.0*n),algorithm的abs()用于取绝对值)

#include<stdio.h>
#include<algorithm>
using namespace std;
typedef long long ll;    //【skill】重命名
struct num
{
  ll zi,mu;  //分子分母
};

ll gcd(ll a,ll b)        //求最大公约数
{
  return b==0 ? a:gcd(b,a%b);
}

num yuefen(num a)        //分数约分
{
  //printf("%lld/%lld。约分为:",a.zi,a.mu);
  if(a.mu<0)          //分母保持正号,统一用分子表示符号
  {
    a.mu=-a.mu;
    a.zi=-a.zi;
  }
  if(a.zi==0)      //分子为0,分数为0,但是加法需要分母相乘合并,将分母设为1方便操作
  {
    a.mu=1;
  }
  else
  {
    int d=gcd(abs(a.zi),abs(a.mu));        //【warning】计算最大公约数的时候要化为正数,abs绝对值
    a.mu/=d;  //得到最大公约数约分
    a.zi/=d;
  }
  //printf("%lld/%lld\n",a.zi,a.mu);
  return a;
}

num ADD(num a,num b)
{
  //printf("%lld/%lld + %lld/%lld=",a.zi,a.mu,b.zi,b.mu);
  num x;
  x.mu=a.mu*b.mu;
  x.zi=a.zi*b.mu+a.mu*b.zi;
  //printf("%lld/%lld  ",x.zi,x.mu);
  return yuefen(x);        //返回约分后的结果
}

void OUT(num a)
{
  yuefen(a);
  if(abs(a.zi)>a.mu)        //带分数【caution】分子在量上面大于分母abs(a.zi)>a.mu,注意绝对值
  {
    int dai=a.zi/a.mu;
    a.zi=abs(a.zi)%a.mu;    //【caution】正负号已经由前面的整数带去了,这里分子要用绝对值保证正数
    if(a.zi==0)          //【warning】约分后为整数,没有分数部分,如6/3=2
      printf("%d",dai);
    else
      printf("%d %lld/%lld",dai,a.zi,a.mu);
  }
  else if(a.mu==1)      //整数
    printf("%lld",a.zi);
  else
  {
    printf("%lld/%lld",a.zi,a.mu);  //真分数
  }
}

int main()
{
  int n;
  scanf("%d",&n);
  num ans;
  ans.mu=1;
  ans.zi=0;
  for(int i=0 ; i<n ; ++i)
  {
    num tmp;
    scanf("%lld/%lld",&tmp.zi,&tmp.mu);
    ans=ADD(ans,tmp);
  }
  OUT(ans);
  return 0;
}
时间: 2024-08-03 15:38:31

PAT:1081. Rational Sum (20) AC(类似math.h中的sqrt(1.0*n),algorithm的abs()用于取绝对值)的相关文章

1081. Rational Sum (20)【模拟】——PAT (Advanced Level) Practise

题目信息 1081. Rational Sum (20) 时间限制400 ms 内存限制65536 kB 代码长度限制16000 B Given N rational numbers in the form "numerator/denominator", you are supposed to calculate their sum. Input Specification: Each input file contains one test case. Each case star

A.1081 Rational Sum (20)

1081 Rational Sum (20)(20 分) Given N rational numbers in the form "numerator/denominator", you are supposed to calculate their sum. Input Specification: Each input file contains one test case. Each case starts with a positive integer N (<=100

1081. Rational Sum (20)

时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue Given N rational numbers in the form "numerator/denominator", you are supposed to calculate their sum. Input Specification: Each input file contains one test case. Each case sta

[PAT] 1081 Rational Sum (20 分)Java

Given N rational numbers in the form numerator/denominator, you are supposed to calculate their sum. Input Specification: Each input file contains one test case. Each case starts with a positive integer N (≤100), followed in the next line N rational

PAT甲题题解-1081. Rational Sum (20)-模拟分数计算

模拟计算一些分数的和,结果以带分数的形式输出注意一些细节即可 #include <iostream> #include <cstdio> #include <algorithm> #include <cstring> #include <cmath> using namespace std; /* 模拟计算一些分数的和,结果以带分数的形式输出 注意一些细节即可 */ const int maxn=105; const int maxv=50000

【PAT甲级】1081 Rational Sum (20 分)

题意: 输入一个正整数N(<=100),接着输入N个由两个整数和一个/组成的分数.输出N个分数的和. 代码: #define HAVE_STRUCT_TIMESPEC#include<bits/stdc++.h>using namespace std;int a[107],b[107];int main(){ ios::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); int n; cin>>n; for(int i

PAT (Advanced Level) 1081. Rational Sum (20)

简单模拟题. #include<cstdio> #include<cstring> #include<cmath> #include<vector> #include<map> #include<stack> #include<queue> #include<string> #include<algorithm> using namespace std; struct FenShu { long l

1081. Rational Sum (20) -最大公约数

题目例如以下: Given N rational numbers in the form "numerator/denominator", you are supposed to calculate their sum. Input Specification: Each input file contains one test case. Each case starts with a positive integer N (<=100), followed in the ne

newcoder PAT 1001 Rational Sum (20)

#include<iostream> #include<stdio.h> #include<cstring> #include<algorithm> using namespace std; int gcd(int a,int b) { return b == 0 ? a: gcd(b,a%b); } int s[105]; int x[105]; int main() { int n; cin >> n; for(int i = 0;i <