卡特兰数。
#include<stdio.h> #include<string.h> const __int64 base=1000000000; const int lenth=100; void mul(__int64 a[],int len,int b) { int i; __int64 jw=0; for(i=len-1;i>=0;i--) { jw=jw+a[i]*b; a[i]=jw%base; jw=jw/base; } } void div(__int64 a[],int len,int b) { int i; __int64 jw=0; for(i=0;i<lenth;i++) { jw=jw*base+a[i]; a[i]=jw/b; jw=jw%b; } } int main() { int i,j,n; __int64 a[101][100]; memset(a[1],0,sizeof(a[1])); a[1][lenth-1]=1; for(i=2;i<=100;i++) { memcpy(a[i],a[i-1],sizeof(a[1])); mul(a[i],lenth,4*i-2); div(a[i],lenth,i+1); } while(scanf("%d",&n)!=EOF) { if(n==-1) break; for(i=0;i<lenth&&a[n][i]==0;i++); printf("%I64d",a[n][i++]); for(;i<lenth;i++) printf("%0*I64d",9,a[n][i]); printf("\n"); } return 0; }
时间: 2024-10-13 12:32:04