另一种阶乘问题
时间限制:
3000 ms | 内存限制:
65535 KB
难度:
1
-
描述
-
大家都知道阶乘这个概念,举个简单的例子:5!=1*2*3*4*5.现在我们引入一种新的阶乘概念,将原来的每个数相乘变为i不大于n的所有奇数相乘例如:5!!=1*3*5.现在明白现在这种阶乘的意思了吧!
现在你的任务是求出1!!+2!!......+n!!的正确值(n<=20)
-
输入
-
第一行输入一个a(a<=20),代表共有a组测试数据
接下来a行各行输入一个n.
输出
- 各行输出结果一个整数R表示1!!+2!!......+n!!的正确值 样例输入
-
2 3 5
样例输出
-
5 23
第一次竟然忘了把数组清零了额……
01.
#include<iostream>
02.
#include<cstring>
03.
using
namespace
std;
04.
int
main()
05.
{
06.
int
a;
07.
cin>>a;
08.
while
(a--)
09.
{
10.
int
sum[20];
11.
int
n,num=1;
12.
cin>>n;
13.
memset
(sum,0,
sizeof
(sum));
14.
for
(
int
i=1;i<=n;i++)
15.
{
16.
for
(
int
j=1;j<=i;j+=2)
17.
{
18.
num*=j;
19.
}
20.
sum[i]+=num;
21.
num=1;
22.
}
23.
int
count=0;
24.
for
(
int
i=1;i<=n;i++)
25.
{
26.
count+=sum[i];
27.
}
28.
cout<<count<<endl;
29.
}
30.
return
0;
31.
}
-
第一行输入一个a(a<=20),代表共有a组测试数据