您的位置:首页 > 其它

南邮 OJ 1223 多重幂计数问题

2015-08-05 11:19 316 查看


多重幂计数问题

时间限制(普通/Java) : 1000 MS/ 3000 MS          运行内存限制 : 65536 KByte
总提交 : 91            测试通过 : 34 

比赛描述

设给定n个变量x1,x2,…,xn。将这些变量依序作底和各层幂,可得n重幂如下



这里将上述n重幂看作是不确定的,当在其中加入适当的括号后,才能成为一个确定的n重幂。不同的加括号方式导致不同的n重幂。例如,当n=4时,全部4重幂有5个。
对n个变量计算出有多少个不同的n重幂。

输入

输入有多行,每一行提供一个数n。

输出

输出多行。对于输入中每一行,在一行中输出不同n重幂的数目。

样例输入

4

样例输出

5

提示

undefined

题目来源

算法设计与实验题解

#include<iostream>
#define N 10001
using namespace std;
int a
={0};
int len=1;
void multiply(int n){
int i;
for(i=0;i<len && i<N;++i){
a[i] *= n;
}
for(i=0;i<len && i<N;++i){
if(a[i]>=10){
a[i+1] += a[i]/10;
a[i] %= 10;
}
}
while(a[len]){
++len;
a[len] += a[len-1]/10;
a[len-1] %= 10;
}
}

void divide(int n){
for(int i=len-1;i;--i){
a[i-1] += (a[i]%n)*10;
a[i] /= n;
}
a[0] /= n;
while(a[len-1]==0){
--len;
}
}
void print(){
int i=len-1;
while(i>=0){
printf("%d",a[i--]);
}
}
void C(int n,int m){
if(n-m<m){
m = n-m;
}
for(int i=0;i<m;++i){
multiply(n--);
}
while(m){
divide(m--);
}
}
int main(){
int n;
while(scanf("%d",&n)!=EOF){
memset(a,0,N);
a[0] = 1;
C(2*n,n);
divide(n+1);
print();
printf("\n");
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息