1088 Rational Arithmetic

#include<iostream>

#include<cstdlib>

using namespace std;

long long a,b,c,d;

//最大公约数

long long gcd(long long t1,long long t2){

if(t2==0){

return abs(t1);

}

return gcd(t2,t1%t2);

}

//进行格式化分数运算

void formatFaction(long long m,long long n){

if(n==0){//如果分母为0

cout<<"Inf";

return ;

}

if(m==0){//如果分子为0

cout<<"0";

return ;

}

//判断是否为负数

bool isNegative((m<0&&n>0)||(m>0&&n<0));

//取绝对值

m=abs(m);

n=abs(n);

//计算整数部分

long long integert=m/n;

//计算分子部分

long long numerator=m%n;

//如果是负数

if(isNegative){

cout<<"(-";

}

//如果有整数部分

if(integert!=0){

cout<<integert;

}

//如果分数为0

if(numerator==0){

if(isNegative){

cout<<")";

}

return;

}

//如果整数和分数都存在

if(integert!=0){

cout<<" ";

}

//约分分数部分

long long divisor=gcd(numerator,n);

numerator/=divisor;

n/=divisor;

//输出分数部分

cout<<numerator<<"/"<<n;

//输出符号结束

if(isNegative){

cout<<")";

}

}

int main(){

char slash;

//读取第一个分数

cin>>a>>slash>>b;

//读取第二个分数

cin>>c>>slash>>d;

//进行加法运算

formatFaction(a,b);

cout<<" + ";

formatFaction(c,d);

cout<<" = ";

formatFaction(a*d+b*c,b*d);

cout<<endl;

//进行减法运算

formatFaction(a,b);

cout<<" - ";

formatFaction(c,d);

cout<<" = ";

formatFaction(a*d-b*c,b*d);

cout<<endl;

//进行乘法运算

formatFaction(a,b);

cout<<" * ";

formatFaction(c,d);

cout<<" = ";

formatFaction(a*c,b*d);

cout<<endl;

//进行除法运算

formatFaction(a,b);

cout<<" / ";

formatFaction(c,d);

cout<<" = ";

if(c==0){

cout<<"Inf";

}else{

formatFaction(a*d,b*c);

}

cout<<endl;

return 0;

}

相关推荐
前端小L4 小时前
贪心算法专题(十):维度权衡的艺术——「根据身高重建队列」
javascript·算法·贪心算法
方得一笔4 小时前
自定义常用的字符串函数(strlen,strcpy,strcmp,strcat)
算法
Xの哲學4 小时前
Linux SMP 实现机制深度剖析
linux·服务器·网络·算法·边缘计算
Thera7774 小时前
状态机(State Machine)详解:原理、优缺点与 C++ 实战示例
开发语言·c++
linux开发之路5 小时前
C++高性能日志库开发实践
c++·c++项目·后端开发·c++新特性·c++校招
wuk9985 小时前
使用PCA算法进行故障诊断的MATLAB仿真
算法·matlab
额呃呃5 小时前
二分查找细节理解
数据结构·算法
无尽的罚坐人生5 小时前
hot 100 283. 移动零
数据结构·算法·双指针
刻BITTER5 小时前
在TRAE 上安装PlatformIO
c++·单片机·嵌入式硬件·arduino
永远都不秃头的程序员(互关)5 小时前
C++动态数组实战:从手写到vector优化
c++·算法