1034 有理数四则运算 (20 分)(测试点三:运行超时)

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

题目链接

算法分析

本题思路是比较简单 的,模拟我们正常计算两个有理数就好了。
关键的难点在于特殊情况的判断:正负,真分数假分数,结果是否为整数和0.

测试点

我卡在了测试点三,运行超时主要是在求最大公约数的地方。解决方法如下:
在这里插入图片描述

代码实现

#include<bits/stdc++.h>
using namespace std;
char op[4] = {'+', '-', '*', '/'};

int gcd(long long a, long long b);
void print(long long a, long long b);

int main(){
	long long a, b, c, d;
 	scanf("%lld/%lld %lld/%lld", &a, &b, &c, &d);
	for(int i = 0; i < 4; ++ i){
		print(a, b);
		printf(" %c ", op[i]);
		print(c, d);
		printf(" = ");
		switch(op[i]){
			case '+':
				print(a * d + b * c, b * d);
				break;
			case '-':
				print(a * d - b * c, b * d);
				break;
			case '*':
				print(a * c, b * d);
				break;
			case '/':
				print(a * d, b * c);
				break;
		}
		printf("\n");
	}
	return 0;
}
int gcd(long long a, long long b){
	long long c;
	if(a < b){
		c = a;
		a = b;
		b = c;
	}
	while((c = a - b)){
		if(a % b == 0) return b;	//防超时 
		a = c > b ? c : b;
		b = c > b ? b : c;
	}
	return a;
}
void print(long long a, long long b){//非常难写的部分 
	long long c;
	if(b == 0){
		printf("Inf");
		return ;
	}
	if(a == 0){
		printf("0");
		return ;
	}
	if((a > 0 && b > 0 )|| (a < 0 && b < 0)){
		a = abs(a);
		b = abs(b);
		if(a > b){
			if(a % b == 0)
				printf("%lld", a / b);
			else{
				printf("%lld ", a / b);	
				print(a % b, b);
			}
		}
		else if(a == b){
			printf("1");
			return ;
		}
		else{
			c = gcd(a, b);
			printf("%lld/%lld", a / c, b / c);
		}
	}
	else{
		a = abs(a);
		b = abs(b);	
		printf("(-");
		print(a,  b);
		printf(")");	
	}
	return ;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Crer_lu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值