博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
P1572 计算分数
阅读量:5291 次
发布时间:2019-06-14

本文共 919 字,大约阅读时间需要 3 分钟。

题目描述

Csh被老妈关在家里做分数计算题,但显然他不愿意坐这么多复杂的计算。况且在家门口还有Xxq在等着他去一起看电影。为了尽快地能去陪Xxq看电影,他把剩下的计算题交给了你,你能帮他解决问题吗?

输入格式

输入一行,为一个分数计算式。计算式中只包含数字、’+’、’-‘、’/’。其中’/’为分数线,分数线左边为分子,右边为分母。输入数据保证不会出现繁分数。如果输入计算式的第一项为正,不会有前缀’+’号;若为负,会有前缀’-‘号。

所有整数均以分数形式出现。

输出格式

输出一行,为最后的计算结果(用最简分数或整数表示)

输入输出样例

输入 #1复制
2/1+1/3-1/4
输出 #1复制
25/12

说明/提示

对于所有测试点,输入计算式长度在100以内,分子、分母在1000以内。

 

 

#include
#include
#include
#include
#include
#include
using namespace std;int a,b,c,d;int gcd(int x,int y){ if(y==0) return x; return gcd(y,x%y);}int main(){ scanf("%d/%d",&a,&b); while(scanf("%d/%d",&c,&d)!=EOF){ int m=gcd(b,d); a*=d/m; c*=b/m; a+=c; b*=d/m; m=gcd(a,b); a/=m; b/=m; } if(b<0){ a=-a; b=-b; } if(b==1){ printf("%d",a); } else{ printf("%d/%d",a,b); } return 0;}

  

转载于:https://www.cnblogs.com/xiongchongwen/p/11450496.html

你可能感兴趣的文章
<每日 1 OJ> -LeetCode 7. 整数反转
查看>>
<每日 1 OJ> -LeetCode 13 . 罗马数字转正数
查看>>
c语言用指针定义一个类型进行输入输出
查看>>
数字电路基础知识
查看>>
C语言之“字符”与“字符串”之间的区别解析
查看>>
<每日 1 OJ> -24. The Simple Problem
查看>>
<每日 1 OJ> -内存文件系统
查看>>
<每日 1 OJ> -LeetCode 28. 实现 strStr()
查看>>
<每日 1 OJ> -LeetCode 21. 合并两个有序链表
查看>>
字符串必须申请内存空间
查看>>
字符串与指针
查看>>
Linux上安装git并在gitlab上建立对应的项目
查看>>
<每日 1 OJ> -LeetCode20. 有效的括号
查看>>
git 学习网站
查看>>
Git常用操作
查看>>
ping-pong buffer
查看>>
Linux 中【./】和【/】和【.】之间有什么区别?
查看>>
Ubuntu sudo 出现 is not in the sudoers file解决方案
查看>>
内存地址对齐
查看>>
看门狗 (监控芯片)
查看>>