C程序-PAT-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

思路:设计一个函数专门打印分数,然后加减乘除根据分数方式处理即可,数据定义为长整型更好处理,

我发现数据都AC有问题,有一种情况没考虑,就是a1/b1=0,a2/b=负数时,这个没考虑 也会通过

#include <iostream>
#include <stdio.h>
#include <stdlib.h>

#define LL long long

int add(LL a1,LL b1,LL a2,LL b2);//加 
int minu(LL a1,LL b1,LL a2,LL b2);//减 
int multi(LL a1,LL b1,LL a2,LL b2);//乘 
int divide(LL a1,LL b1,LL a2,LL b2);//除 
int num(LL a,LL b);//打印分数 
LL gcd(LL a,LL b);//求最大公约数 

int main( ) 
{
	LL a1,b1,a2,b2;//输入的时候是整形,但是相乘之后可能出现长整型 
	scanf("%lld/%lld %lld/%lld",&a1,&b1,&a2,&b2);
	
	add(a1,b1,a2,b2);
	minu(a1,b1,a2,b2);
	multi(a1,b1,a2,b2);
	divide(a1,b1,a2,b2);
	
	return 0;
}

int add(LL a1,LL b1,LL a2,LL b2)
{
	num(a1,b1);
	printf(" + ");
	num(a2,b2); 
	printf(" = ");
	num(a1*b2+a2*b1,b2*b1);//分数加法 
	printf("\n");
	
	return 0;
}

int minu(LL a1,LL b1,LL a2,LL b2)
{
	num(a1,b1);
	printf(" - ");
	num(a2,b2); 
	printf(" = ");
	num(a1*b2-a2*b1,b2*b1);//分数减法 
	printf("\n");
	
	return 0;
}

int multi(LL a1,LL b1,LL a2,LL b2)
{
	num(a1,b1);
	printf(" * ");
	num(a2,b2); 
	printf(" = ");
	num(a1*a2,b1*b2);//分数乘法 
	printf("\n");
	
	return 0;
}

int divide(LL a1,LL b1,LL a2,LL b2)
{
	num(a1,b1);
	printf(" / ");
	num(a2,b2); 
	printf(" = ");
	if(a2==0)//分母为0,打印Inf 
	{
		printf("Inf\n");
		return 0;
	
	}

	num(a1*b2,b1*a2);//分数除法 
	printf("\n");
	
	return 0;
}

int num(LL a,LL b) 
{
    int sign = 1;
    LL getgcd;
    
    //负负得正,如果分子为负,也就不用加负号 
    if (a < 0&& b!=0)
	{
        a = -a;
        sign = sign * -1;
    }
    if (b < 0&& a!=0) 
	{
        b = -b;
        sign = sign * -1;
    }
    getgcd = gcd(a, b);//求最大公约数 
    a = a / getgcd;
    b = b / getgcd;//化简 
    if (sign == -1) printf("(-");//判断符号 
	if(a%b==0)//整数 
	{
		printf("%lld",a/b);
		if(sign==-1)
			printf(")");
		return 0;
	}
	else
	{
		if(a/b)//带分数 
		{
			printf("%lld ",a/b);
			a=a%b;//真分数分子 
		}
		printf("%lld/%lld",a,b);//真分数 
		if(sign==-1)//判断符号 
			printf(")");
		return 0;
	}
}

LL gcd(LL a,LL b)
{
	if(b==0) return a;
	else return gcd(b,a%b);
}

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值