C语言求分数的四则运算并以分数形式表示

输入含有两个分数的表达式求出其结果以分数形式表示
解决思路:将两个分数通分后运算并将其结果约分输出
有错误欢迎指出
C代码如下:

#include <stdio.h>
int n1,n2;//定义全局变量n1、n2分别存放分子和分母 
int main()
{
	void cal(int a,int b,int c,int d,char ch);//cal函数计算出分数运算后的结果,未约分 
	void fun();//用来对n1和n2进行约分 
	int a,b,c,d;
	char ch;
	printf("请输入表达式:");
	scanf("%ld/%ld%c%ld/%ld",&a,&b,&ch,&c,&d);
	cal(a,b,c,d,ch);//计算出还未约分的分子分母 
	fun();// 计算出约分后的分子分母 
	printf("%ld/%ld%c%ld/%ld=%ld/%ld\n",a,b,ch,c,d,n1,n2);
	return 0;                                                              
}
void cal(int a,int b,int c,int d,char ch)
{
	switch(ch)
	{
		case'+':n1=a*d+b*c;n2=b*d;break;
		case'-':n1=a*d-b*c;n2=b*d;break;
		case'*':n1=a*c;n2=b*d;break;
		case'/':n1=a*d;n2=b*c;break;
		default:printf("Error!\n");
	}
}
void fun()
{
	for(int i=2;i<=n1 && i<=n2;i++)
		 while(n1%i==0 && n2%i==0)
		 {
		 	n1=n1/i;
		 	n2=n2/i;
		 }
}
  • 6
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
好的,我可以回答这个问题。以下是用 C 语言写有理数的四则运算的代码,包含菜单: #include <stdio.h> typedef struct { int numerator; // 分子 int denominator; // 分母 } Rational; // 最大公约数 int gcd(int a, int b) { return b == ? a : gcd(b, a % b); } // 化简分数 void simplify(Rational *r) { int g = gcd(r->numerator, r->denominator); r->numerator /= g; r->denominator /= g; } // 加法 Rational add(Rational r1, Rational r2) { Rational result; result.numerator = r1.numerator * r2.denominator + r2.numerator * r1.denominator; result.denominator = r1.denominator * r2.denominator; simplify(&result); return result; } // 减法 Rational subtract(Rational r1, Rational r2) { Rational result; result.numerator = r1.numerator * r2.denominator - r2.numerator * r1.denominator; result.denominator = r1.denominator * r2.denominator; simplify(&result); return result; } // 乘法 Rational multiply(Rational r1, Rational r2) { Rational result; result.numerator = r1.numerator * r2.numerator; result.denominator = r1.denominator * r2.denominator; simplify(&result); return result; } // 除法 Rational divide(Rational r1, Rational r2) { Rational result; result.numerator = r1.numerator * r2.denominator; result.denominator = r1.denominator * r2.numerator; simplify(&result); return result; } int main() { Rational r1, r2, result; int choice; printf("请输入第一个有理数的分子和分母,用空格隔开:"); scanf("%d %d", &r1.numerator, &r1.denominator); printf("请输入第二个有理数的分子和分母,用空格隔开:"); scanf("%d %d", &r2.numerator, &r2.denominator); printf("请选择要进行的运算:\n"); printf("1. 加法\n"); printf("2. 减法\n"); printf("3. 乘法\n"); printf("4. 除法\n"); printf("请输入选项:"); scanf("%d", &choice); switch (choice) { case 1: result = add(r1, r2); printf("结果为:%d/%d\n", result.numerator, result.denominator); break; case 2: result = subtract(r1, r2); printf("结果为:%d/%d\n", result.numerator, result.denominator); break; case 3: result = multiply(r1, r2); printf("结果为:%d/%d\n", result.numerator, result.denominator); break; case 4: result = divide(r1, r2); printf("结果为:%d/%d\n", result.numerator, result.denominator); break; default: printf("无效选项!\n"); break; } return ; }
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值