PAT (Basic Level) Practise (中文)-1034. 有理数四则运算(20)
PAT (Basic Level) Practise (中文)-1034. 有理数四则运算(20) http://www.patest.cn/contests/pat-b-practise/1034
本题要求编写程序,计算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 分析:本题目没有思维的难度,只是可能处理起来有点啰嗦烦人,所以建议一定要单独写成小功能函数。
比如:
1. 输出的每个有理数必须是该有理数的最简形式“k a/b”,其中k是整数部分,a/b是最简分数部分
2. 若为负数,则须加括号
3. 若除法分母为0,则输出“Inf”。
#include<stdio.h>
void jianhua(long long *fenzi,long long *fenmu)
{
if(*fenzi== || *fenmu==)
{
*fenzi=,*fenmu=;
return;
}
int flag1=,flag2= ;// 1负数 2正数
if(*fenzi<) flag1=,*fenzi=-*fenzi;
if(*fenmu<) flag2=,*fenmu=-*fenmu;
long long max=,min=;
if(*fenzi>*fenmu) max=*fenzi,min=*fenmu;
else min=*fenzi,max=*fenmu;
while(max%min)
{
if(max-min>min)
max=max-min;
else
{
min=max-min;
max=max-min;
}
}
*fenzi/=min,*fenmu/=min;
if(flag1) *fenzi=-*fenzi;
if(flag2) *fenmu=-*fenmu;
if(*fenmu<) *fenzi=-*fenzi,*fenmu=-*fenmu;
return;
}
void outlook(long long a,long long b,int i,long long c) //输出 函数
{
int flag=;
if(a<) {flag=;a=-a;printf("(-");}
if(i== && c==) printf("Inf"); //i==3时代表除法运算
else if(a==) printf(""); //分子为0,即数==0
else if(a/b) { if(a%b) printf("%lld %lld/%lld",a/b,a%b,b);
else printf("%lld",a/b);
}else printf("%lld/%lld",a,b); //可以整除,即简化为整数
if(flag) printf(")");
}
int main()
{
long long *pfenzi=,*pfenmu=;
long long a=,b=,c=,d=,fenzi=,fenmu=; //因为两个整数相乘,可能超出int范围,所以使用了long long
scanf("%lld/%lld %lld/%lld",&a,&b,&c,&d);
pfenzi=&a;
pfenmu=&b;
jianhua(pfenzi,pfenmu); //第一个数
pfenzi=&c;
pfenmu=&d;
jianhua(pfenzi,pfenmu); //第二个数
char op[]={'+','-','*','/'};
for(int i=;i<;i++)
{
//'+','-','*','/' 依次处理
if(==i) { fenzi=a*d+c*b; fenmu=b*d; }
else if(==i) { fenzi=a*d-c*b; fenmu=b*d; }
else if(==i) { fenzi=a*c; fenmu=b*d; }
else { fenzi=a*d; fenmu=b*c; }
pfenzi=&fenzi;
pfenmu=&fenmu;
jianhua(pfenzi,pfenmu); // 简化当前处理运算的结果
// 格式输出
if(i) printf("\n");
outlook(a,b,i,); //第一个数
printf(" %c ",op[i]); // 运算符
outlook(c,d,i,); //第二个数
printf(" = ");
outlook(fenzi,fenmu,i,c); //结果
}
return ;
}
好讨厌这道题。。。难度不高,却这么复杂。。。好考验耐心。。。
PAT (Basic Level) Practise (中文)-1034. 有理数四则运算(20)的更多相关文章
- PAT (Basic Level) Practise (中文)-1039. 到底买不买(20)
PAT (Basic Level) Practise (中文)-1039. 到底买不买(20) http://www.patest.cn/contests/pat-b-practise/1039 小红 ...
- PAT (Basic Level) Practise (中文)- 1022. D进制的A+B (20)
PAT (Basic Level) Practise (中文)- 1022. D进制的A+B (20) http://www.patest.cn/contests/pat-b-practise/1 ...
- PAT (Basic Level) Practise (中文)- 1024. 科学计数法 (20)
PAT (Basic Level) Practise (中文)- 1024. 科学计数法 (20) http://www.patest.cn/contests/pat-b-practise/1024 ...
- PAT (Basic Level) Practise (中文)-1025. 反转链表 (25)
PAT (Basic Level) Practise (中文)-1025. 反转链表 (25) http://www.patest.cn/contests/pat-b-practise/1025 ...
- PAT (Basic Level) Practise (中文)- 1026. 程序运行时间(15)
PAT (Basic Level) Practise (中文)- 1026. 程序运行时间(15) http://www.patest.cn/contests/pat-b-practise/10 ...
- PAT (Basic Level) Practise (中文)-1027. 打印沙漏(20)
PAT (Basic Level) Practise (中文)-1027. 打印沙漏(20) http://www.patest.cn/contests/pat-b-practise/1027 本题 ...
- PAT (Basic Level) Practise (中文)-1028. 人口普查(20)
PAT (Basic Level) Practise (中文)-1028. 人口普查(20) http://www.patest.cn/contests/pat-b-practise/1028 某 ...
- PAT (Basic Level) Practise (中文)-1029. 旧键盘(20)
PAT (Basic Level) Practise (中文)-1029. 旧键盘(20) http://www.patest.cn/contests/pat-b-practise/1029 旧键盘上 ...
- PAT (Basic Level) Practise (中文)-1030. 完美数列(25)
PAT (Basic Level) Practise (中文)-1030. 完美数列(25) http://www.patest.cn/contests/pat-b-practise/1030 给 ...
随机推荐
- layui常用功能
包含的主要样式: 验证不通过时的弹窗 弹窗修改信息 询问框(是否删除之类的) 操作成功提示.操作失败提示 加载样式(显示加载层) 文件下载请前往github over!over!over!
- 点击a标签 跳到当前页面指定div
给标签div设一个id值 <div id="aa"><div> a标签抓取id值,点击跳过去 <a href="#aa">& ...
- mysql引擎问题研究
mysql引擎问题研究 数据库引擎 缺省情况下,MYSQL支持三个引擎:ISAM,MYISAM和HEAP.还存在MYSQL+API的引擎例如InnoDB. 数据库引擎特点 ISAM:执行读取操作速度很 ...
- 第二十篇 .NET高级技术之C#中的线程(二) 线程同步基础
1.同步要领 下面的表格列展了.NET对协调或同步线程动作的可用的工具: 简易阻止方法 构成 目的 Sleep 阻止给定的时间周期 Join 等待另一个线程 ...
- 初识DetNet:确定性网络的前世今生
在刚刚落幕的2019中国 SDN/NFV/AI大会上,确定性网络(Deterministic Networking)成为了大家讨论的热点话题之一.随着工业物联网(IIoT)的兴起和工业4.0的提出,T ...
- 基于nginx的配置网站密码认证
在nginx配置服务中,创建访问网站密码认证. 1)需要ngx_http_auth_basic_module模块 语法: Syntax: auth_basic string | off; Defaul ...
- Mybatis中分页存在的坑1
站在巨人的肩膀上 https://www.cnblogs.com/esileme/p/7565184.html 环境:Spring 4.2.1 Mybatis 3.2.8 pagehelper 5.1 ...
- javascript 数组、json连接
json(或数组).concat(需要添加的json(或数组))
- foreach循环与迭代器循环 删除插入元素的区别
(1)仅对其遍历而不修改容器大小时,只使用foreach循环 (2)需要边遍历边修改容器大小时(插入删除元素),只使用迭代器循环 import java.util.HashMap;import ja ...
- jupyter notebook dead kernel问题解决
背景: 我在刚安装好的tensorflow环境下启动jupyter notebook,无论是浏览器还是控制台,提示都是关于dead kernel.然后就查嘛,更新大发好. 但是我在控制台里按照其他人说 ...