本题要求编写程序,计算2个有理数的和、差、积、商。

输入格式:

输入在一行中按照“a1/b1 a2/b2”的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只可能出现在分子前,分母不为0。

输出格式:

分别在4行中按照“有理数1 运算符 有理数2 = 结果”的格式顺序输出2个有理数的和、差、积、商。注意输出的每个有理数必须是该有理数的最简形式“k a/b”,其中k是整数部分,a/b是最简分数部分;若为负数,则须加括号;若除法分母为0,则输出“Inf”。题目保证正确的输出中没有超过整型范围的整数。
输入样例1:

2/3 -4/2

输出样例1:

2/3 + (-2) = (-1 1/3)
2/3 - (-2) = 2 2/3
2/3 * (-2) = (-1 1/3)
2/3 / (-2) = (-1/3)

输入样例2:

5/3 0/6

输出样例2:

1 2/3 + 0 = 1 2/3
1 2/3 - 0 = 1 2/3
1 2/3 * 0 = 0
1 2/3 / 0 = Inf

错误代码:

/*************************************************************************> File Name: 1034.c> Author: YueBo > Function: 有理数的四则运算> Created Time: 2016年11月18日 星期五 12时55分10秒************************************************************************/#include <stdio.h>
#include <stdlib.h>
#include <math.h>
struct rNum1 {long long a, b;
};void print(struct rNum1* pr)
{long long m, m1, n, q, i;n = abs(pr->b);if (n == 0) { //如果分母为0,啥都不用说了printf("Inf");return;}m = abs(pr->a) % abs(pr->b);q = pr->a / pr->b;if (m != 0) { //化简真分数for (i = 2; i <= m; i++) {if (m%i==0 && n%i==0) {m = m / i;n = n / i;i = 1; //刚开始i=2老是出错}}}if (pr->a >= 0) {if (m == 0) {  //如果分子为0printf("%lld", q);} else if (q != 0) {printf("%lld %lld/%lld", q, m, n);} else {printf("%lld/%lld", m, n);}} else {if (m == 0) {printf("(%lld)", q);}else if (q != 0) {printf("(%lld %lld/%lld)", q, m, n);} else {printf("(-%lld/%lld)", m, n);}}
}void plus(struct rNum1* pr1, struct rNum1* pr2, struct rNum1* pr3)
{pr3->b = pr1->b * pr2->b;pr3->a = pr1->a * pr2->b + pr2->a * pr1->b;
}void minus(struct rNum1* pr1, struct rNum1* pr2, struct rNum1* pr3)
{pr3->b = pr1->b * pr2->b;pr3->a = pr1->a * pr2->b - pr2->a * pr1->b;
}void times(struct rNum1* pr1, struct rNum1* pr2, struct rNum1* pr3)
{pr3->b = pr1->b * pr2->b;pr3->a = pr1->a * pr2->a;
}void division(struct rNum1* pr1, struct rNum1* pr2, struct rNum1* pr3)
{if (pr2->a > 0) {pr3->b = pr1->b * pr2->a;pr3->a = pr1->a * pr2->b;} else {pr3->b = (-1)*pr1->b * pr2->a;pr3->a = (-1)*pr1->a * pr2->b;}
}int main()
{struct rNum1 r1, r2, r3;scanf("%lld/%lld", &r1.a, &r1.b);scanf("%lld/%lld", &r2.a, &r2.b);//加法plus(&r1, &r2, &r3);print(&r1);printf(" + ");print(&r2);printf(" = ");print(&r3);printf("\n");//减法minus(&r1, &r2, &r3);print(&r1);printf(" - ");print(&r2);printf(" = ");print(&r3);printf("\n");//乘法times(&r1, &r2, &r3);print(&r1);printf(" * ");print(&r2);printf(" = ");print(&r3);printf("\n");//除法division(&r1, &r2, &r3);print(&r1);printf(" / ");print(&r2);printf(" = ");print(&r3);return 0;
}

提示错误:

1034. 有理数四则运算(20)相关推荐

  1. C++学习之路 | PTA乙级—— 1034 有理数四则运算 (20 分)(精简)

    1034 有理数四则运算 (20 分) 本题要求编写程序,计算 2 个有理数的和.差.积.商. 输入格式: 输入在一行中按照 a1/b1 a2/b2 的格式给出两个分数形式的有理数,其中分子和分母全是 ...

  2. PAT (Basic Level) Practise (中文)-1034. 有理数四则运算(20)

    PAT (Basic Level) Practise (中文)-1034. 有理数四则运算(20)  http://www.patest.cn/contests/pat-b-practise/1034 ...

  3. 【2020模拟考试T4】【PAT乙】1034 有理数四则运算 (20分) 测试点2

    problem 1034 有理数四则运算 (20分) 本题要求编写程序,计算 2 个有理数的和.差.积.商. 输入格式: 输入在一行中按照 a1/b1 a2/b2 的格式给出两个分数形式的有理数,其中 ...

  4. 1034 有理数四则运算 (20 分)(c语言)(测试点三)

    本题要求编写程序,计算 2 个有理数的和.差.积.商. 输入格式: 输入在一行中按照 a1/b1 a2/b2 的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只可能出现在分子前 ...

  5. PAT 乙级 1034. 有理数四则运算(20) Java版

    本题要求编写程序,计算2个有理数的和.差.积.商. 输入格式: 输入在一行中按照"a1/b1 a2/b2"的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只 ...

  6. 1034. 有理数四则运算(20)-PAT乙级真题

    本题要求编写程序,计算2个有理数的和.差.积.商. 输入格式: 输入在一行中按照"a1/b1 a2/b2"的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只 ...

  7. 1034 有理数四则运算 (20分)

    本题要求编写程序,计算 2 个有理数的和.差.积.商. 输入格式: 输入在一行中按照 a1/b1 a2/b2 的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只可能出现在分子前 ...

  8. 【PAT乙级】1034 有理数四则运算 (20 分)

    题目地址 #include<bits/stdc++.h> using namespace std; typedef long long int LL; LL gcd(LL a,LL b) ...

  9. Pat乙级 1034 有理数四则运算

    Pat乙级 1034 有理数四则运算 思路 代码 题目网址 https://pintia.cn/problem-sets/994805260223102976/problems/99480528762 ...

最新文章

  1. 【Groovy】Gradle 构建工具 ( 自动下载并配置构建环境 | 提供 API 扩展与开发工具集成 | 内置 Maven 和 Ivy 依赖管理 | 使用 Groovy 编写构建脚本 )
  2. 使用ASP.NET MVC Futures 中的异步Action
  3. Ruby的module(模块)
  4. 第一阶段:Java基础之控制结构
  5. 修改计算机用户权限,如何修改一个电脑账户为最低权限
  6. 网站需要密码登录访问php源码
  7. 解决Xshell无法连接虚拟机CentOS7问题
  8. bzoj千题计划227:bzoj1486: [HNOI2009]最小圈
  9. Facebook开源新NLP框架:简化部署流程,大规模应用也OK
  10. 把java程序打包成.exe
  11. 【Linux】最常用命令:简单易学,但能解决95%以上的问题
  12. HTTP代理服务器 - CONNECT SSL/TLS 原理
  13. Ab压力测试Http
  14. Modeling and Enhancing Low-Quality Retinal Fundus Images
  15. 注塑机压铸机比例阀控制放大器
  16. vue xlsx.js获取单元格数据类型的hooks 单元格类型处理
  17. 报错SyntaxError: Unexpected token T in JSON at position 0 at JSON.parse (<anonymous>)的解决方法
  18. 小型初创公司Trisymbiotic IP(R)宣布,其美国专利10,020,436的设施效率超越美国和中国最快的超级计算机
  19. cfa的pv怎么用计算机算,怎么用金融计算器算pv(金融计算器怎么用)
  20. 羊了个羊增加版:鸡了个鸡,坤了个坤

热门文章

  1. spring学习(8):log4j.properties 详解与配置步骤
  2. 第二十一期:拜托!面试不要再问我Spring Cloud底层原理
  3. 隔离型RS232串口电路
  4. eureka需要替换吗_nacos无缝替换eureka
  5. PHP闭包(Closure)初探(转载 http://my.oschina.net/melonol/blog/126694?p=2#comments)
  6. ASP.NET MVC 5 入门教程 (3) 路由route
  7. geoserver native JAI error 问题解决方法
  8. 去除标题_资深运营导师-云中教你轻松写标题
  9. elasticsearch 6.x (一) 部署 windows入门 spingboot连接
  10. Centos7安装SVN+HTTP