1034. 有理数四则运算(20)
本题要求编写程序,计算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)相关推荐
- C++学习之路 | PTA乙级—— 1034 有理数四则运算 (20 分)(精简)
1034 有理数四则运算 (20 分) 本题要求编写程序,计算 2 个有理数的和.差.积.商. 输入格式: 输入在一行中按照 a1/b1 a2/b2 的格式给出两个分数形式的有理数,其中分子和分母全是 ...
- PAT (Basic Level) Practise (中文)-1034. 有理数四则运算(20)
PAT (Basic Level) Practise (中文)-1034. 有理数四则运算(20) http://www.patest.cn/contests/pat-b-practise/1034 ...
- 【2020模拟考试T4】【PAT乙】1034 有理数四则运算 (20分) 测试点2
problem 1034 有理数四则运算 (20分) 本题要求编写程序,计算 2 个有理数的和.差.积.商. 输入格式: 输入在一行中按照 a1/b1 a2/b2 的格式给出两个分数形式的有理数,其中 ...
- 1034 有理数四则运算 (20 分)(c语言)(测试点三)
本题要求编写程序,计算 2 个有理数的和.差.积.商. 输入格式: 输入在一行中按照 a1/b1 a2/b2 的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只可能出现在分子前 ...
- PAT 乙级 1034. 有理数四则运算(20) Java版
本题要求编写程序,计算2个有理数的和.差.积.商. 输入格式: 输入在一行中按照"a1/b1 a2/b2"的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只 ...
- 1034. 有理数四则运算(20)-PAT乙级真题
本题要求编写程序,计算2个有理数的和.差.积.商. 输入格式: 输入在一行中按照"a1/b1 a2/b2"的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只 ...
- 1034 有理数四则运算 (20分)
本题要求编写程序,计算 2 个有理数的和.差.积.商. 输入格式: 输入在一行中按照 a1/b1 a2/b2 的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只可能出现在分子前 ...
- 【PAT乙级】1034 有理数四则运算 (20 分)
题目地址 #include<bits/stdc++.h> using namespace std; typedef long long int LL; LL gcd(LL a,LL b) ...
- Pat乙级 1034 有理数四则运算
Pat乙级 1034 有理数四则运算 思路 代码 题目网址 https://pintia.cn/problem-sets/994805260223102976/problems/99480528762 ...
最新文章
- 【Groovy】Gradle 构建工具 ( 自动下载并配置构建环境 | 提供 API 扩展与开发工具集成 | 内置 Maven 和 Ivy 依赖管理 | 使用 Groovy 编写构建脚本 )
- 使用ASP.NET MVC Futures 中的异步Action
- Ruby的module(模块)
- 第一阶段:Java基础之控制结构
- 修改计算机用户权限,如何修改一个电脑账户为最低权限
- 网站需要密码登录访问php源码
- 解决Xshell无法连接虚拟机CentOS7问题
- bzoj千题计划227:bzoj1486: [HNOI2009]最小圈
- Facebook开源新NLP框架:简化部署流程,大规模应用也OK
- 把java程序打包成.exe
- 【Linux】最常用命令:简单易学,但能解决95%以上的问题
- HTTP代理服务器 - CONNECT SSL/TLS 原理
- Ab压力测试Http
- Modeling and Enhancing Low-Quality Retinal Fundus Images
- 注塑机压铸机比例阀控制放大器
- vue xlsx.js获取单元格数据类型的hooks 单元格类型处理
- 报错SyntaxError: Unexpected token T in JSON at position 0 at JSON.parse (<anonymous>)的解决方法
- 小型初创公司Trisymbiotic IP(R)宣布,其美国专利10,020,436的设施效率超越美国和中国最快的超级计算机
- cfa的pv怎么用计算机算,怎么用金融计算器算pv(金融计算器怎么用)
- 羊了个羊增加版:鸡了个鸡,坤了个坤
热门文章
- spring学习(8):log4j.properties 详解与配置步骤
- 第二十一期:拜托!面试不要再问我Spring Cloud底层原理
- 隔离型RS232串口电路
- eureka需要替换吗_nacos无缝替换eureka
- PHP闭包(Closure)初探(转载 http://my.oschina.net/melonol/blog/126694?p=2#comments)
- ASP.NET MVC 5 入门教程 (3) 路由route
- geoserver native JAI error 问题解决方法
- 去除标题_资深运营导师-云中教你轻松写标题
- elasticsearch 6.x (一) 部署 windows入门 spingboot连接
- Centos7安装SVN+HTTP