分数求和算法

本文详细探讨了分数求和的算法,从基本概念到实际操作步骤,包括同分母、不同分母分数的加法,以及如何简化结果。通过实例解析,帮助读者深入理解分数加法的数学原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include"stdio.h"
//这个程序确实可以完成求和的计算但是结果是不准确的
int main()
{
	int i;
	double s = 0;
	for (i = 1; i <= 9; i++)
	{
		s = s + 1.0*i / (i + 1);
	}
	return 0;
}


//这个分数求和的准确性高
#define N 9
struct Rational
{
	long r1, r2;//分子r1,分母r2
};
//求最大公约数
int gcd(int a, int b)
{
	int i;
	for (i = a < b ? a : b; i >= 1; i--)
	{
		if (a%i == 0 && b%i == 0)
		{
			break;
		}
	}
	return i;
}
int main()
{
	struct Rational x[N];
	struct Rational result;
	int i, t1, t2, t;
	for (i = 0; i < N; i++)//用结构体数组存储数据
	{
		x[i].r1 = i + 1;
		x[i].r2 = i + 2;
	}
	result = x[0];
	for (i = 1; i < N; i++)
	{
		t1 = result.r1*x[i].r2 + result.r2*x[i].r1;//新的分子
		t2 = result.r2*x[i].r2;//新的分母
		t = gcd(t1, t2);
		result.r1 = t1 / t;//约去最大公约数,简化分子
		result.r2 = t2 / t;
	}
	printf("%ld/%ld\n", result.r1, result.r2);
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

彭就是我的姓i

你的鼓励是我创作的动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值