PTA之N个数求和(细节题)天梯赛

本文涉及的产品
实时数仓Hologres,5000CU*H 100GB 3个月
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
智能开放搜索 OpenSearch行业算法版,1GB 20LCU 1个月
简介: 编程题,要求计算以分子/分母形式给出的一组有理数的和,输出结果也要是最简有理数形式。输入包含正整数N(N≤100)及N个有理数,输出为和的最简形式。示例:输入5个数2/5, 4/15, 1/30, -2/60, 8/3,输出3 1/3;输入2个数4/3, 2/3,输出2。代码中包含求最大公约数的函数和计算有理数和的主要逻辑。

本题的要求很简单,就是求N个数字的和。麻烦的是,这些数字是以有理数分子/分母的形式给出的,你输出的和也必须是有理数的形式。

输入格式:

输入第一行给出一个正整数N100)。随后一行按格式a1/b1 a2/b2 ...给出N个有理数。题目保证所有分子和分母都在长整型范围内。另外,负数的符号一定出现在分子前面。

输出格式:

输出上述数字和的最简形式 —— 即将结果写成整数部分 分数部分,其中分数部分写成分子/分母,要求分子小于分母,且它们没有公因子。如果结果的整数部分为0,则只输出分数部分。

输入样例1:

5

2/5 4/15 1/30 -2/60 8/3

输出样例1:

3 1/3

输入样例2:

2

4/3 2/3

输出样例2:

2

输入样例3:

3

1/3 1/6 1/8

输出样例3:

7/24

#include

long long  zui(long long a,long long b)

{

   /*if(a%b!=0)return zui(b,a%b);

   else

       return b; */

  /* long long n;

 

 while(b!=0)

 {

   n=a%b;

   a=b;

   b=n;

 }

 return a;*///这是一种利用辗转相除法求最大公约数的方法(可用)

   if(b!=0)return zui(b,a%b); //这是一种递归求公约数的方法,其基本原理也是利用辗转相除法(可用)

}

int main()

{

 long  long a[150],c[150];

 long  long b,d,c1,c2,sum1=0,sum2=0,k=0,h=0;

 char ch;

 scanf("%lld",&b);//规定的分数的个数

 for(int i=0;i<b;i++)

 {

   scanf("%lld%c%lld",&a[i],&ch,&c[i]);//此处也可写为scanf("%lld/%lld",&a[i],&c[i]);

   

 }

 sum2=c[0];

 for(int i=1;i<b;i++)

 {

   k=sum2*c[i];

   sum2=k/zui(sum2,c[i]);//此处是求各个分数的公分母,为了不使值超出long long的范围,每两项求一下最小公倍数;---北冥注释

 }

 for(int m=0;m<b;m++) { sum1=sum1+a[m]*(sum2/c[m]);//求各个分子的和;(sum2/c[m])必须加括号因为如果先算a[m]*sum2会导致数可能超出 } // long long 的范围; 当然也可写成sum2/c[m]*a[m]的形式,此处只是提醒一下 d=zui(sum1,sum2); // 这个细节,因为这个坑很难发现---北冥注释QQ80374779 c1=sum1/d; c2=sum2/d; if(c1%c2==0)printf("%lld",c1/c2);//因为如果有整数部分时负号总是出现在整数部分,所以此处不必考虑负号的有无 if(c1%c2!=0) { if(c1/c2!=0)printf("%lld ",c1/c2); if(c2>=0)printf("%lld/%lld",c1%c2,c2);//如果分子中没有负数

   if(c2<0)                             //如果分子中有负数,把负数变为正数

   {                                    

     c2=-c2;                          

     if(c1/c2==0)printf("-");     //如果此分母没有整数部分,那么此时负号必须移动到分子前面;

     printf("%lld/%lld",c1%c2,c2);

   }  

 }

 return 0;

}

目录
相关文章
|
5月前
【洛谷 P1035】[NOIP2002 普及组] 级数求和 题解(循环)
**NOIP2002普及组题目:求级数$S_n=1+\frac{1}{2}+\frac{1}{3}+...+\frac{1}{n}$超过$k$的最小$n$。给定$1\leq k\leq 15$,输出满足$S_n&gt;k$的$n$。输入$1$个整数$k$,输出相应$n$。例如,输入$1$,输出$2$。代码中使用double确保精度,通过累加求和判断条件找到$n$。**
37 0
|
6月前
|
C语言
pta浙大版《C语言程序设计(第3版)》 习题6-4 使用函数输出指定范围内的Fibonacci数 (20分)
pta浙大版《C语言程序设计(第3版)》 习题6-4 使用函数输出指定范围内的Fibonacci数 (20分)
|
6月前
|
C语言
浙大版《C语言程序设计(第3版)》题目集 练习8-2 计算两数的和与差 (10分)
浙大版《C语言程序设计(第3版)》题目集 练习8-2 计算两数的和与差 (10分)
|
6月前
|
C语言
pta 浙大版《C语言程序设计(第3版)》题目集 习题6-6 使用函数输出一个整数的逆序数 (20分)
pta 浙大版《C语言程序设计(第3版)》题目集 习题6-6 使用函数输出一个整数的逆序数 (20分)
|
6月前
考研高数之无穷级数题型三:将函数展开成幂级数和傅里叶级数(题目讲解)
考研高数之无穷级数题型三:将函数展开成幂级数和傅里叶级数(题目讲解)
111 0
|
算法
【蓝桥杯】求既约分数—>(全解)最大公约数与最小公倍数
【蓝桥杯】求既约分数—>(全解)最大公约数与最小公倍数
78 0
|
存储
蓝桥杯19国赛-矩阵计数
蓝桥杯19国赛-矩阵计数
83 0
|
算法 Python
算法创作|PTA-求满足条件的斐波那契数
算法创作|PTA-求满足条件的斐波那契数
179 0
|
C语言 C++
PTA团体程序设计天梯赛-练习集: L1-050 倒数第N个字符串 ( 15分 )
给定一个完全由小写英文字母组成的字符串等差递增序列,该序列中的每个字符串的长度固定为 L,从 L 个 a 开始,以 1 为步长递增。例如当 L 为 3 时,序列为 { aaa, aab, aac, ..., aaz, aba, abb, ..., abz, ..., zzz }。这个序列的倒数第27个字符串就是 zyz。对于任意给定的 L,本题要求你给出对应序列倒数第 N 个字符串。 输入格式: 输入在一行中给出两个正整数 L(2 ≤ L ≤ 6)和 N(≤105)。 输出格式: 在一行中输出对应序列倒数第 N 个字符串。题目保证这个字符串是存在的。 输入样例:
169 0