ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

[PTA]7-35 有理数均值

2021-09-11 16:34:42  阅读:207  来源: 互联网

标签:有理数 num1 num2 int denominator numerator PTA 35 fraction


本题要求编写程序,计算N个有理数的平均值。

输入格式:

输入第一行给出正整数N(≤100);第二行中按照a1/b1 a2/b2 …的格式给出N个分数形式的有理数,其中分子和分母全是整形范围内的整数;如果是负数,则负号一定出现在最前面。

输出格式:

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

输入样例1:

4
1/2 1/6 3/6 -5/10
结尾无空行

输出样例1:

1/6
结尾无空行

输入样例2:

2
4/3 2/3

输出样例2:

1
  • 提交结果:

在这里插入图片描述

  • 源码:
#include<stdio.h>

typedef struct
{
	int numerator;
	int denominator;
}Fraction;

/* 求数num1和num2的最大公因数 */
int gcd(int num1, int num2);

int main(void)
{
	int N;
	int numerator, denominator, greatestCommonFactor;		// 分子、分母、最大公因数
	Fraction fraction[100];

	scanf("%d", &N);

	for (int i = 0; i < N; i++)
	{
		scanf("%d/%d", &fraction[i].numerator, &fraction[i].denominator);
	}

	/* 初始化最终结果的分子、分母为输入的第一个分数 */
	numerator = fraction[0].numerator;
	denominator = fraction[0].denominator;

	for (int i = 1; i < N; i++)
	{
		/* 通分 */
		numerator = numerator * fraction[i].denominator + fraction[i].numerator * denominator;
		denominator *= fraction[i].denominator;
		/* 化为最简分式,避免溢出 */
		greatestCommonFactor = gcd(numerator, denominator);
		numerator /= greatestCommonFactor;
		denominator /= greatestCommonFactor;
	}

	/* 分母乘上N,求有理数均值,而后化简*/
	denominator *= N;
	greatestCommonFactor = gcd(numerator, denominator);
	numerator /= greatestCommonFactor;
	denominator /= greatestCommonFactor;

	/* 按要求格式输出结果 */
	if (denominator == 1)
	{
		printf("%d", numerator);
	}
	else
	{
		printf("%d/%d", numerator, denominator);
	}

	return 0;
}

/* 求数num1和num2的最大公因数 */
int gcd(int num1, int num2)
{
	if (num2 == 0)
	{
		return 1;
	}

	while (num1 % num2 != 0)
	{
		int temp = num1 % num2;
		num1 = num2;
		num2 = temp;
		temp = num1 % num2;
	}

	return num2;
}

标签:有理数,num1,num2,int,denominator,numerator,PTA,35,fraction
来源: https://blog.csdn.net/weixin_51008866/article/details/120239355

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有