飞行的猪哼哼

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

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;
	}
}

posted on 2018-10-28 16:52  飞行的猪哼哼  阅读(61)  评论(0)    收藏  举报