牛客网 – 简单的分数(模拟)

牛客网 – 简单的分数(模拟)题目链接 https ac nowcoder com acm contest 322 L 时间限制 C C 1 秒 其他语言 2 秒空间限制 C C 32768K 其他语言 65536K64bitI l

大家好,欢迎来到IT知识分享网。

题目描述

John最近对分数很感兴趣,在研究分数的加减运算。现在要求计算两个分数的运算。

输入描述:

输出描述:

输出分数运算结果“x/y”,要求x/y是最简分数。

输入

输出

备注:

如果有运算符,应在x前面,如“-1/6”,而不是“1/-6”。

解题思路

简单的模拟题,模拟一下分数加减的运算过程就行了,注意最后要判断一下公约数的正负就行了。

#include <iostream> using namespace std; int gcd(int a, int b) { return b ? gcd(b, a % b) : a; } int main() { int n, t, u, v, a, b, c, d, op, uv; scanf("%d", &t); while (t--) { scanf("%d%d%d%d%d", &op, &a, &b, &c, &d); if (op) v = a * d + b * c; else v = a * d - b * c; u = b * d; uv = gcd(u, v); if (uv < 0) uv = -uv; printf("%d/%d\n", v / uv, u / uv); } return 0; }

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/107376.html

(0)

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信