码迷,mamicode.com
首页 > 其他好文 > 详细

分数加减法

时间:2017-05-27 21:15:38      阅读:154      评论:0      收藏:0      [点我收藏+]

标签:分数   char   pos   style   ret   结果   时间   多行   strong   

分数加减法

时间限制:3000 ms  |  内存限制:65535 KB

难度:2

描写叙述

编写一个C程序,实现两个分数的加减法

输入

输入包括多行数据
每行数据是一个字符串,格式是"a/boc/d"
当中a, b, c, d是一个0-9的整数。o是运算符"+"或者"-"

数据以EOF结束
输入数据保证合法

输出

对于输入数据的每一行输出两个分数的运算结果。
注意结果应符合书写习惯。没有多余的符号、分子、分母,而且化简至最简分数

例子输入

1/8+3/8

1/4-1/2

1/3-1/3

例子输出

1/2

-1/4

0

代码1:

#include<stdio.h>
int main(void)
{
	int x,y,x1,y1;
	char o;
	while(scanf("%d/%d%c%d/%d",&x,&y,&o,&x1,&y1)!=EOF)
	{
		int x2,y2;
		y2=y*y1;
		if(o==‘+‘)
		  x2=x*y1+x1*y;
		else
		  x2=x*y1-x1*y;
		int max=x2>y2?x2:y2;
		for(int i=2;i<=max/2;i++)
		{
			if(x2%i==0&&y2%i==0)
			{
				x2=x2/i;
				y2=y2/i;
				i=2;
			}
		}
		if(x2==0)
		  printf("%d\n",x2);
		else if(x2%y2==0)
		   printf("%d\n",x2/y2);
		else
		   printf("%d/%d\n",x2,y2);
	}
	return 0;
}


代码2:

#include<stdio.h>
int main(void)
{
	char ch[7];
	int a,b,c,d,m,n,s,t,r;
	while(scanf("%s",ch)!=EOF)
	{
		b=ch[2]-‘0‘;
		d=ch[6]-‘0‘;
		if(b!=d)
		{
			if(b>d)
			{
				t=b;
				b=d;
				d=t;
			}
			m=b;
			while(m%d!=0)
			   m=m+b;
		}
		else
		    m=b;
		a=m*(ch[0]-‘0‘)/(ch[2]-‘0‘);
		c=m*(ch[4]-‘0‘)/(ch[6]-‘0‘);
		if(ch[3]==‘+‘)
		  n=a+c;
		if(ch[3]==‘-‘)
		  n=a-c;
		t=m;
		if(n<0)
		  s=-n;
		else
		  s=n;
		printf("%d  %d  %d   %d   \n",m,s,a,c);
		while(s!=0)
		{
			r=t%s;
			t=s;
			s=r;
		}
		if((m/t)==1)
		   printf("%d\n",n/t);
		else
		   printf("%d/%d\n",n/t,m/t);
	}
	return 0;
 } 





分数加减法

标签:分数   char   pos   style   ret   结果   时间   多行   strong   

原文地址:http://www.cnblogs.com/mthoutai/p/6914352.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!