❶ 如何用C语言编程输入两个分数求和并以最简分式的方式输出
#include "stdio.h"
int fun(int num1,int num2)/*求最大公约数函数*/
{
int a,b,temp;
if(num1<num2)
{
temp=num1;
num1=num2;
num2=temp;
}
a=num1;
b=num2;
while(b!=0)/*利用辗除法,直到b为0为止*/
{
temp=a%b;
a=b;
b=temp;
}
return a;
}
main()
{
int a1,a2,b1,b2,c=1,num1,num2;
printf("请输入第一个分数的分子:\n");
scanf("%d",&a1);
printf("请输入第一个分数的分和胡母:\n");
scanf("%d",&a2);
printf("唤卜拦请输入第一个分数的分子弊橘:\n");
scanf("%d",&b1);
printf("请输入第一个分数的分母:\n");
scanf("%d",&b2);
num1=a1*b2+b1*a2;
num2=a2*b2;
c=fun(num1,num2);
num1=num1/c;
num2=num2/c;
if(num2==1)
printf("结果为:%d:",num1);
else
printf("结果为:%d/%d:",num1,num2);
}
❷ 如何用C语言编程输入两个分数求和并以最简分式的方式输出
输入可以用如下格式:
unsigned int a,b,c,d;
scanf("%d/%d",&a,&b);/*a/b*/
scanf("%d/%d",&c,&d);/*c/d*/
求最大公因数,可以用辗转相除法;公分母=b、d的最小公倍数=b*d/b、d的最大公约数,
通分后,分子相加,结果的分子、分母用辗转相除法求最大公约数,进行约分。
约分后的结果输出。