基础编程题目集 —— 7-33 有理数加法**

1 题目要求

本题要求编写程序,计算两个有理数的和。

输入格式:
输入在一行中按照a1/b1 a2/b2的格式给出两个分数形式的有理数,其中分子和分母全是整形范围内的正整数。

输出格式:
在一行中按照a/b的格式输出两个有理数的和。注意必须是该有理数的最简分数形式,若分母为1,则只输出分子。

2 样例

输入样例1:
1/3 1/6

输出样例1:
1/2

输入样例2:
4/3 2/3

输出样例2:
2

3 分析

(1)实际上是两个分式的加法运算
判断分母是否相同,
相同,则直接分子相加,然后分子分母约分。

不同,首先将两个分式的分母通分,

  • 两个分式的分母不互质(可约分),把小分母对应的项的分子变为 分子*(大分母/小分母)
  • 两个分式的分母互质(不可约分),两个分式的分母通分为 原始分母的乘积,分子也进行通分。

(2)注意:

  • 求最大公约数的函数本身有交换大小功能
  • 变量在更新值之后,仍然需要更新之前的值,则需要临时变量保存原值。

4 代码

#include <stdio.h>
int gcd2(int a,int b)
{
  if(a%b==0)
  	return b;
  else
    return gcd2(b,a%b);
}
int change(int *a,int *b)
{
  int tmp=*a;
  *a=*b;
  *b=tmp;
  return 0;
}
int rationalAdd(int a1,int b1,int a2,int b2)
{
  int c,d;

  if(b1!=b2)
  {
    //小 + 大
    if(b1>b2)
  	{
      change(&b1,&b2);
      change(&a1,&a2);
  	}
	  //通分
    if(b2%b1==0)
    {//两个分母可约分
        //!!!
      a1=a1*(b2/b1);
      b1=b2;
      //printf("%d %d\n",a1,b2);
    }
    else{//两个分母不互质
      int orig_b1=b1;
      b1=b1*b2;
      a1=a1*b2;
     // b2=b2*b1;
      a2=a2*orig_b1;
   //   printf("%d %d\n",a1+a2,b1);
    }
  }
  //分母
  d=b1;
  //分子
  c=a1+a2;
  //!!!!
  if(d/gcd2(c,d)==1)
  	printf("%d",c/gcd2(c,d));
  else
    printf("%d/%d",c/gcd2(c,d),d/gcd2(c,d));
  return 0;
}
int main()
{
   int a1,b1,a2,b2;
   scanf("%d/%d %d/%d",&a1,&b1,&a2,&b2);
   rationalAdd(a1,b1,a2,b2);
   return 0;
}

5 总结

(1)根据两个分母的大小 和分母之间互质关系进行分类讨论

### 使用数据结构实现有理数加法 为了有效地处理有理数并实现其加法运算,通常会创建一个专门的数据结构来封装有理数的相关属性及其行为。这里介绍一种基于面向对象编程的方式,在 Python 中通过自定义类 `Rational` 来管理有理数,并提供方法完成两个有理数之间的加法操作。 #### 定义 Rational 类 首先需要设计一个名为 `Rational` 的类,该类内部维护着两个整型成员变量——分子 (`numerator`) 和分母 (`denominator`) 。此外还需要重载构造器以便于初始化实例化对象时传入具体的数值参数[^1]: ```python class Rational: def __init__(self, numerator=0, denominator=1): self.numerator = numerator gcd_value = math.gcd(self.numerator, denominator) self.denominator = denominator // gcd_value self.numerator //= gcd_value if self.denominator < 0: self.denominator = abs(self.denominator) self.numerator = -self.numerator elif self.denominator == 0: raise ValueError("Denominator cannot be zero.") ``` 上述代码片段实现了对输入值的规范化处理,确保任何新创建的对象都处于最简形式;同时也防止了非法状态的发生(比如零作为除数)。注意这里的最大公约数计算是为了让最终得到的结果尽可能简洁明了[^4]。 #### 实现加法规则 当涉及到具体算术逻辑的时候,则遵循数学上的通分原则来进行两者的求和过程。即先找到最小公倍数 lcm(a,b),再按照公式 `(a * b / a + c * d / b)` 进行转换后相加即可获得新的分子部分,而共同拥有的那个分母就是之前提到过的lcm(a,b)[^4]: ```python def add(self, other): from fractions import Fraction result_numerator = (self.numerator * other.denominator + other.numerator * self.denominator) result_denominator = self.denominator * other.denominator return Rational(result_numerator, result_denominator) # 测试用例 r1 = Rational(1, 2) r2 = Rational(3, 4) print(f"{r1} + {r2} =", r1.add(r2)) ``` 此段程序展示了完整的加法功能实现方式,并附带了一个简单的测试例子用来验证正确性。值得注意的是,实际应用中可能还会考虑更多边界情况以及性能优化等问题[^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值