Problem Description
编写一个C程序,实现两个分数的加减法
Input
输入包含多行数据
每行数据是一个字符串,格式是"a/boc/d"。
其中a, b, c, d是一个0-9的整数。o是运算符"+“或者”-"。
数据以EOF结束
输入数据保证合法
Output
对于输入数据的每一行输出两个分数的运算结果。
注意结果应符合书写习惯,没有多余的符号、分子、分母,并且化简至最简分数
Sample Input
1/8+3/8
1/4-1/2
1/3-1/3
Sample Output
1/2
-1/4
0
解析:
首先字符串输入手动分割
两个分母相乘,如果是加号两个分子乘相对分母后相加,反之相减。
如果此时分子等于0,则直接输出0,如果分子小于0,先输出负号。
然后调用类求分子分母的最大公因数,然后分子分母同时除以最大公因数
最后输出即可。
import java.util.Scanner;
public class Main
{
public static void main(String[] args)
{
Scanner reader=new Scanner(System.in);
while(reader.hasNext())
{
String s=reader.next();
int a=(int)(s.charAt(0)-'0');
int b=(int)(s.charAt(2)-'0');
int c=(int)(s.charAt(4)-'0');
int d=(int)(s.charAt(6)-'0');
char x=s.charAt(3);
int n=b*d;
int m= 0;
if(x=='+')
{
m=a*d+c*b;
}
else if(x=='-')
{
m=a*d-c*b;
}
if(m==0)
{
System.out.println("0");
continue;
}
if(m<0)
{
System.out.print("-");
m=-m;
}
Max max=new Max(n, m);
int flag=max.Maxll();
n=n/flag;
m=m/flag;
if(n==1)System.out.println(m);
else System.out.println(m+"/"+n);
}
reader.close();
}
}
class Max
{
int n;
int m;
int flag=0;
public Max(int n,int m)
{
this.n=n;
this.m=m;
}
public int Maxll()
{
for(int i=n;i>=1;i--)
{
if(n%i==0&&m%i==0)
{
flag=i;
break;
}
}
return flag;
}
}
浙公网安备 33010602011771号