鱼C论坛

 找回密码
 立即注册
查看: 1413|回复: 3

[已解决]L1-009 N个数求和

[复制链接]
发表于 2020-9-26 22:27:11 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
输入格式:
输入第一行给出一个正整数N(≤100)。随后一行按格式a1/b1 a2/b2 ...给出N个有理数。题目保证所有分子和分母都在长整型范围内。另外,负数的符号一定出现在分子前面。

输出格式:
输出上述数字和的最简形式 —— 即将结果写成整数部分 分数部分,其中分数部分写成分子/分母,要求分子小于分母,且它们没有公因子。如果结果的整数部分为0,则只输出分数部分。

这是我的代码:

  1. #include <bits/stdc++.h>

  2. using namespace std;

  3. int gcd(int, int);

  4. int main()
  5. {
  6.     int n;
  7.     char ch;
  8.     int res_a = 0, res_b = INT_MIN;
  9.     cin >> n;
  10.     for (int i = 0; i < n; i++){
  11.         int a, b;
  12.         cin >> a >> ch >> b;
  13.         if(res_a == 0){
  14.             if(a){
  15.                 res_a = a;
  16.                 res_b = b;
  17.             }
  18.         }else{
  19.             int tmp = res_b;
  20.             int tmp_gcd = gcd(res_b, b);
  21.             res_b = res_b * b / tmp_gcd;
  22.             res_a = (b * res_a + a * tmp) / tmp_gcd;
  23.         }
  24.     }
  25.     if(res_a == 0){
  26.         cout << 0 << endl;
  27.         return 0;
  28.     }

  29.     int g = gcd(res_a, res_b);
  30.     res_a /= g;
  31.     res_b /= g;
  32.     int zhengshu = res_a / res_b;
  33.     res_a -= (zhengshu * res_b);
  34.     if(zhengshu)
  35.         cout << zhengshu;
  36.     if(res_a){
  37.         if(zhengshu)
  38.             cout << ' ';
  39.         cout << res_a << '/' << res_b;
  40.     }

  41.     cout << endl;

  42.     system("pause");
  43.     return 0;
  44. }

  45. int gcd(int m, int n){
  46.     m = abs(m);
  47.     n = abs(n);
  48.     if(n == 0)
  49.         return m;
  50.     else
  51.         return gcd(n, m % n);
  52. }
复制代码
六个测试点有五个是对的,有一个错了,请问有哪儿有问题啊
最佳答案
2020-9-26 22:35:43
题目要求的是长整型范围内,你定义的是int,是不是这个问题?
你把int改为long试试?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-9-26 22:28:24 | 显示全部楼层
我也不知道测试点的测试用例是啥,所以也没办法根据测试用例来改代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-26 22:35:43 | 显示全部楼层    本楼为最佳答案   
题目要求的是长整型范围内,你定义的是int,是不是这个问题?
你把int改为long试试?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-26 22:46:53 | 显示全部楼层
sunrise085 发表于 2020-9-26 22:35
题目要求的是长整型范围内,你定义的是int,是不是这个问题?
你把int改为long试试?

是这样,我读题太不仔细了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-6 09:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表