题目描述
上小学四年级的小王同学虽然很笨,但他非常喜欢钻研奥数题。他遇到了这样的一个计算分数的问题:S(n)=1/3+3/5+5/7+…+n/(n+2),n为小于40的奇数。题目要求根据n来计算S(n)的值。他苦思冥想也没找出规律来解这道题,其实这道题目根本就没有规律,是老师用来难为不听话的学生用的。小王同学知道了实情后仍然不放弃去解这道题。当n值很大时,用纸笔计算非常费力,用计算器也很麻烦,有的计算器也不能计算分数。现在他只能求助你来编程帮他实现计算S(n)了,注意S(n)的计算结果应为分数形式。
输入与输出要求:
输入一个整数n,n的范围是1—40,且为奇数。输出S(n)的计算结果,如输出S(3)的结果:“14/15”。
程序运行效果:
Sample 1:
7↙
764/315
Sample 2:
21↙
2861599189/334639305
Sample 3:
39↙
116320091982737732/6845630929362225
注意:每次计算都应进行约分,否则会溢出
#include<iostream>
using namespace std;
struct number
{
long long a,b;
};
int main()
{
int x;
long long m, n, r;
cin >> x;
number num;
num.a = 1, num.b = 3;
if (x == 1)
cout << 1 << "/" << 3;
else if (x == 3)
cout << 14 << "/" << 15;
else
{
for (int i = 3; i <= x; i += 2)
{
num.a = num.a*(i + 2) + num.b*i;
num.b = num.b*(i + 2);
m = num.a, n = num.b;
r = m%n;
while (r)
{
m = n;
n = r;
r = m%n;
}
num.a = num.a / n;
num.b = num.b / n;
}
cout << num.a << "/" << num.b;
}
return 0;
}