PAT 1034 有理数四则运算(20)(代码框架+思路+测试点错误分析)
1034 有理数四则运算(20)(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 = InfPS:
我的思路:用一个长度为4的数组分别存储整数部分(0)、分子(1)、分母(2)、符号(3),这道题要实现的3个功能
1、化简:首先取出分子分母的符号(注意负负得正),用最大公约数化简分子分母,若分母不为0,可以将它化为带分数。
2、计算:这里我用4维数组(c[4][4])存储运算后的分数,注意我们只需要计算分子分母,其他工作,我们交给化简函数。
3、输出分数:在化简之后,按题目要求将分数转化为字符串返回。
请看代码注释。
注意:1、求最大公约数,时间复杂度要低(测试点2、3 运行超时)
2、需要使用long long类型,未化简之前的分子分母会超出范围(测试点3浮点错误)
3、注意符号(同号为正、异号为负):这里注意负负得正(测试点3答案错误)
4、输出部分的空格要控制好,否则出现格式错误。
#include<iostream>
#include<string>
using namespace std;
long long max(long long a, long long b) {		//获取最大公约数
	return b == 0 ? a : max(b, a % b);
}
long long classify(long long a[4]) {		//化简分数
	a[0] = 0;	//初始化整数部分
	a[3] = 1;   //初始化符号
	if (a[1] < 0) {
		a[1] = abs(a[1]);
		a[3] *= -1;  //符号累乘
	}
	if (a[2] < 0) {
		a[2] = abs(a[2]);
		a[3] *= -1;
	}
	long long i = max(a[1], a[2]);
	a[1] /= i;
	a[2] /= i;
	if (a[2]) {			//确保分母不为0,化简为带分数。
		a[0] = a[1] / a[2];
		a[1] %= a[2];
	}
	return 0;
}
string show(long long a[4]) {			//按题目要求返回该分数
	string s;
	if (a[2] == 0)         //分母为0,报错
		return "Inf";
	if (a[0] == 0 && a[1] == 0)   //整数部分和分子同时为0,返回‘0’
		return "0";
	if (a[0])    //整数部分存在,则加入
		s += (to_string(a[0]));
	if (a[0] && a[1])   //如果还存在分数部分,中间有' '(空格)
		s += ' ';
	if (a[1])       //分子存在,则加入分数部分
		s += (to_string(a[1]) + '/' + to_string(a[2]));
	if (a[3] == -1)      //如果为负数,需要加负号和括号
		s = "(-" + s + ")";
	return s;
}
int main()
{
	long long a[4], b[4], c[4][4];  //数组分别存储整数部分、分子、分母和符号。
	char ch;
	cin >> a[1] >> ch >> a[2] >> b[1] >> ch >> b[2];
	c[0][1] = a[1] * b[2] + a[2] * b[1];
	c[0][2] = a[2] * b[2];
	c[1][1] = a[1] * b[2] - a[2] * b[1];
	c[1][2] = a[2] * b[2];
	c[2][1] = a[1] * b[1];
	c[2][2] = a[2] * b[2];
	c[3][1] = a[1] * b[2];
	c[3][2] = a[2] * b[1];
	classify(a);
	classify(b);
	classify(c[0]);
	classify(c[1]);
	classify(c[2]);
	classify(c[3]);
	cout << show(a) << " + " << show(b) << " = " << show(c[0]) << endl;
	cout << show(a) << " - " << show(b) << " = " << show(c[1]) << endl;
	cout << show(a) << " * " << show(b) << " = " << show(c[2]) << endl;
	cout << show(a) << " / " << show(b) << " = " << show(c[3]) << endl;
	return 0;
}PAT 1034 有理数四则运算(20)(代码框架+思路+测试点错误分析)的更多相关文章
- PAT 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 ... 
- PAT-乙级-1034. 有理数四则运算(20)
		1034. 有理数四则运算(20) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 本题要求编写程序,计算2个有理 ... 
- PAT Basic 1034 有理数四则运算(20) [数学问题-分数的四则运算]
		题目 本题要求编写程序,计算2个有理数的和.差.积.商. 输⼊格式: 输⼊在⼀⾏中按照"a1/b1 a2/b2"的格式给出两个分数形式的有理数,其中分⼦和分⺟全是整型范围内的整数, ... 
- PAT乙级1034. 有理数四则运算(20)
		本题要求编写程序,计算2个有理数的和.差.积.商. 输入格式: 输入在一行中按照“a1/b1 a2/b2”的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只可能出现在分子前,分 ... 
- 1034 有理数四则运算 (20 分)C语言
		题目描述 本题要求编写程序,计算2个有理数的和.差.积.商. 输入描述: 输入在一行中按照"a1/b1 a2/b2"的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整 ... 
- PAT 1034 有理数四则运算
		https://pintia.cn/problem-sets/994805260223102976/problems/994805287624491008 本题要求编写程序,计算2个有理数的和.差.积 ... 
- PAT——1034. 有理数四则运算
		本题要求编写程序,计算2个有理数的和.差.积.商. 输入格式: 输入在一行中按照“a1/b1 a2/b2”的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只可能出现在分子前,分 ... 
- PAT 1028 人口普查(20)(STL-set+思路+测试点分析)
		1028 人口普查(20)(20 分) 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是合理的--假设已知镇上没有超 ... 
随机推荐
- SQL Server2016 配置管理器
			SQL Server2016 以后版本配置管理器的配置管理器不再同数据库工具集成,是单独的应用. Windows 10: 要打开 SQL Server 配置管理器,请在“起始页”中键入 SQLServ ... 
- 清理mysql binlog日志
			1.查看binlog日志 mysql> show binary logs; +------------------+------------+| Log_name | File_ ... 
- leetcode108
			/** * Definition for a binary tree node. * public class TreeNode { * public int val; * public TreeNo ... 
- PHP依赖注入(DI)和控制反转(IoC)详解
			这篇文章主要介绍了PHP依赖注入(DI)和控制反转(IoC)的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 首先依赖注入和控制反转说的是同一个东西,是一种设计模式,这种设计模式用来减少程 ... 
- 1.mysql ERROR 1045 (28000): 错误解决办法
			转自:https://www.cnblogs.com/jpwz/p/6061214.html ERROR 1045 (28000): Access denied for user 'ODBC'@'lo ... 
- ant 注意
			nt文件在部署时,如果控制台出现乱码则需要调整语言. 高版本eclipse在jdk高版本中已经植入了ant的部署.因此不需要单独配置ant.jar. 如果版本低,可下载ant插件,或者下载ant的工具 ... 
- BLOB 操作
			对于数据库是BLOB类型存储数据. BLOB数据插入: Oracle提供的标准方式: 先插入一个空BLOB对象,然后Update这个空对象. 首先使用empty_blob()函数插入一个空BLOB对象 ... 
- libcur+openssl的编译,使之支持SSL<转>
			本机环境: Visual Studio 2010 . Windows 7 64 bit 1: 下载文件 1.1 libcurl: curl-7.49.1.zip 地址: https://curl.ha ... 
- SAP订单状态最详细的解释
			order status description explanation CRTD 建立 生产订单创建时的状态,表明订单处于刚刚创建时点,不允许做后续发料,确认等操作. PREL 部分释放(部分下达) ... 
- svn更新代码时控制台出现的英文字母表示什么意思
			U:表示从服务器收到文件更新了 G:表示本地文件以及服务器文件都已经更新,而且成功的合并了 A:表示有文件或者目录添加到工作目录 R:表示文件或者目录被替换了 C:表示文件的本地修改和服务器修改发生冲 ... 
