12:分数求和

45 篇文章 1 订阅

总时间限制: 

1000ms

 

内存限制: 

65536kB

描述

输入n个分数并对他们求和,并用最简形式表示。所谓最简形式是指:分子分母的最大公约数为1;若最终结果的分母为1,则直接用整数表示。

如:5/6、10/3均是最简形式,而3/6需要化简为1/2, 3/1需要化简为3。

分子和分母均不为0,也不为负数。

输入

第一行是一个整数n,表示分数个数,1 <= n <= 10;
接下来n行,每行一个分数,用"p/q"的形式表示,不含空格,p,q均不超过10。

输出

输出只有一行,即最终结果的最简形式。若为分数,用"p/q"的形式表示。

样例输入

2
1/2
1/3

样例输出

5/6

 

写这个题的原因使a/b+c/d=(ad+bc)/bd 这样的话,就可以一边读入一边相加了,最后约到公约数就可以,这边用的gcd的方法来求的最大公约数,有兴趣的朋友可以去看看我之前写的一篇关于gcd的证明。 

这里初始化的时候需要注意,应该让c=0,d=1。

#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	cin>>n;
	int a,b,c=0,d=1;
	for(int i=1;i<=n;i++)
	{
		scanf("%d/%d",&a,&b);
		c=a*d+b*c;
		d=b*d;
	}
	a=c;
	b=d;
	while(b)
	{
		int c=a%b;
		a=b;
		b=c;
	}
	c/=a;
	d/=a;
	if(d!=1) cout<<c<<'/'<<d<<endl;
	else cout<<c<<endl;
	return 0; 
}

 

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在 Python 中,可以使用 `fractions` 模块来进行分数运算。该模块提供了 `Fraction` 类来表示分数,可以进行加、减、乘、除等运算。 下面是一个示例代码,演示如何使用 `fractions` 模块进行分数求和: ```python from fractions import Fraction # 定义两个分数 a = Fraction(1, 2) b = Fraction(3, 4) # 求和 c = a + b # 输出结果 print(c) # 输出 5/4 ``` 在上面的代码中,我们首先导入了 `fractions` 模块,然后分别定义了两个分数 `a` 和 `b`,分别为 1/2 和 3/4。接着,我们使用加号运算符对它们进行求和,将结果赋值给变量 `c`。最后,我们输出了求和结果 `c`,它的值为 5/4。 如果要求多个分数的和,可以使用循环来依次累加。下面是一个示例代码,演示如何求多个分数的和: ```python from fractions import Fraction # 定义一个分数列表 fractions = [ Fraction(1, 2), Fraction(3, 4), Fraction(1, 3), Fraction(2, 5), ] # 求和 s = sum(fractions) # 输出结果 print(s) # 输出 37/30 ``` 在上面的代码中,我们首先定义了一个分数列表 `fractions`,包含了四个分数。然后,我们使用内置函数 `sum` 对它们进行求和,将结果赋值给变量 `s`。最后,我们输出了求和结果 `s`,它的值为 37/30。 ### 回答2: Python 中可以使用 Fraction 模块来处理分数计算。首先需要导入 Fraction 模块,然后可以使用 Fraction 类来创建分数对象。例如,Fraction(1,3) 表示 1/3 分数。 要进行分数求和,可以使用 Fraction 类中的加法操作符来实现。在将所有分数相加之前,可以先创建一个初始值为 0 的 Fraction 对象作为结果变量。然后遍历所有分数,将每个分数都加到结果变量中。最后输出结果变量。 下面是一个计算分数求和的示例代码: ```python from fractions import Fraction def sum_of_fractions(fractions): result = Fraction(0,1) for fraction in fractions: result += fraction return result fractions = [Fraction(1,3), Fraction(1,4), Fraction(1,6)] sum_result = sum_of_fractions(fractions) print(sum_result) ``` 以上代码中,我们定义了一个 sum_of_fractions 函数,它接受一个分数列表作为参数。函数内部创建了一个初始值为 0 的 Fraction 对象 result,然后将每个分数都加到 result 中。最后返回计算结果。在主程序中,我们定义了一个 fractions 列表,并将一些分数添加到其中。然后调用 sum_of_fractions 函数计算分数求和,并将结果打印出来。 以上就是用 Python 计算分数求和的方法。希望对你有帮助! ### 回答3: 要使用 Python 求解分数的和,可以使用 Python 内置的分数模块 `fractions`。 首先,需要导入 `fractions` 模块:`import fractions` 然后,可以使用 `fractions.Fraction` 创建分数对象,并进行相加操作。 例如,我们想求解 1/4、1/3 和 2/5 三个分数的和: ``` import fractions # 创建分数对象 frac1 = fractions.Fraction(1, 4) frac2 = fractions.Fraction(1, 3) frac3 = fractions.Fraction(2, 5) # 求解分数的和 sum_frac = frac1 + frac2 + frac3 # 打印结果 print(sum_frac) ``` 运行上述代码,将会输出分数的和。在这个例子中,输出的结果为 29/60。 需要注意的是,Python 的 `fractions` 模块会自动进行约分,所以不需要担心结果没有进行化简。 除了求和之外,`fractions` 模块还提供了其他常用的分数操作,如减法、乘法、除法、取倒数、比较大小等。可以根据具体需求进行操作。 希望以上回答能够帮到你!
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值