题目是说给出一个数字,然后以1到这个数为序号当做二叉树的结点,问总共有几种组成二叉树的方式。这个题就是用卡特兰数算出个数,然后因为有编号,不同的编号对应不同的方式,所以结果是卡特兰数乘这个数的阶乘种方案。因为数字比较大,所以要用高精度的方法也就是用字符数组来做,我分别写了三个函数,一个算加法,一个算乘法,最后一个打表,等打出表来最后只要判断一下输入的数是第几个,直接输出就行了,下面是我的代码,第一次写高精度的这种大数处理,可能看上去比较繁琐= =

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
char ans[][];
char ads[],mus[];
char jc[][];
char res[][]; int multiply(char* a1,char* b1)
{
memset(mus,,sizeof(mus));
int i,j,k;
int len,len1,len2;
len1=strlen(a1);
len2=strlen(b1);
int mut=,t;
bool va[];
int s[],adt[];
char a[],b[];
memset(s,,sizeof(s));
memset(adt,,sizeof(adt));
memset(va,,sizeof(va));
for(i=len1-,j=;i>=;i--)
{
a[i]=a1[j];
j++;
}
for(i=len2-,j=;i>=;i--)
{
b[i]=b1[j];
j++;
}
for(i=;i<len1;i++)
{
mut=;
for(j=;j<len2;j++)
{
t=(a[i]-'')*(b[j]-'')+mut;
mut=;
if(t>=)
{
mut=t/;
t=t%;
}
s[i+j]=t+s[i+j]+adt[i+j];
va[i+j]=;
adt[i+j]=;
if(s[i+j]>=)
{
if(!va[i+j+])
adt[i+j+]=s[i+j]/+adt[i+j+];
else
adt[i+j+]=s[i+j]/;
s[i+j]=s[i+j]%;
}
}
s[i+j]=mut;
}
s[i+j-]=mut+adt[i+j-];
if(s[i+j-]!=)
k=i+j-;
else
k=i+j-;
for(i=k,j=;i>=;i--)
{
mus[i]=(s[j]+'');
j++;
}
return ;
} int additive(char* a,char* b)
{
memset(ads,,sizeof(ads));
int len,len1,len2;
int i;
int ad[];
len1=strlen(a);
len2=strlen(b);
if(len1==len2)
{
len=len1;
}
else if(len1>len2)
{
len=len1;
for(i=len;i>=len-len2;i--)
{
b[i]=b[i-len+len2];
}
for(i=len-len2-;i>=;i--)
{
b[i]='';
}
}
else if(len1<len2)
{
len=len2;
for(i=len;i>=len-len1;i--)
{
a[i]=a[i-len+len1];
}
for(i=len-len1-;i>=;i--)
{
a[i]='';
}
}
int t=;
for(i=len-;i>=;i--)
{
ad[i]=(a[i]-'')+(b[i]-'')+t;
t=;
if(ad[i]>=)
{
t++;
ad[i]=ad[i]-;
ads[i]=ad[i]+'';
}
else
{
ads[i]=ad[i]+'';
}
}
if(t==)
{
for(i=len;i>=;i--)
{
ads[i]=ads[i-];
}
ads[]='';
}
return ;
} int excel()
{
ans[][]='';
ans[][]='';
char sum[];
int n;
int i,j;
char t[];
memset(sum,,sizeof(sum));
for(i=;i<=;i++)
{
for(j=i;j>;j--)
{
multiply(ans[i-j],ans[j-]);
additive(mus,sum);
strcpy(sum,ads);
}
strcpy(ans[i],sum);
memset(sum,,sizeof(sum));
}
jc[][]='';
for(i=;i<;i++)
{
memset(t,,sizeof(t));
if(i>=)
{
t[]=i/+'';
t[]=i%+'';
}
else
{
t[]=i+'';
}
multiply(jc[i-],t);
strcpy(jc[i],mus);
}
multiply(jc[],"");
strcpy(jc[],mus);
for(i=;i<=;i++)
{
multiply(ans[i],jc[i]);
strcpy(res[i],mus);
//cout<<"res["<<i<<"]="<<res[i]<<endl;
}
return ;
} int main()
{
int n;
excel();
while(scanf("%d",&n)!=EOF)
{
if(n==)
break;
cout<<res[n]<<endl;
}
return ;
}

HDU 1131 Count the Trees 大数计算的更多相关文章

  1. Uva 10007 / HDU 1131 - Count the Trees (卡特兰数)

     Count the Trees  Another common social inability is known as ACM (Abnormally Compulsive Meditation) ...

  2. HDU 1131 Count the Trees

    卡特兰数再乘上n的阶乘 #include<iostream> #include<cstdio> using namespace std; #define base 10000 ...

  3. hdu 1130,hdu 1131(卡特兰数,大数)

    How Many Trees? Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)T ...

  4. zjuoj 3602 Count the Trees

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3602 Count the Trees Time Limit: 2 Seco ...

  5. Count the Trees[HDU1131]

    Count the Trees Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)T ...

  6. hdu 1023 卡特兰数《 大数》java

    Train Problem II Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  7. js 大数计算

    js 大数计算 原理 JavaScript 安全整数 是 -253-1 ~ 253-1 ,即: -9007199254740991 ~ 9007199254740991; 换句话说,整数超过这个范围就 ...

  8. HDU 4588 Count The Carries 计算二进制进位总数

    点击打开链接 Count The Carries Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java ...

  9. HDU 1042 大数计算

    这道题一开始就采用将一万个解的表打好的话,虽然时间效率比较高,但是内存占用太大,就MLE 这里写好大数后,每次输入一个n,然后再老老实实一个个求阶层就好 java代码: /** * @(#)Main. ...

随机推荐

  1. Atian inputmethod 输入法解决方案 方言与多语言多文字支持 英语汉字汉语阿拉伯文的支持 (au

    Atian inputmethod 输入法解决方案 方言与多语言多文字支持 英语汉字汉语阿拉伯文的支持 (au 1.1. Overview概论 支持母语优先的战略性产品,主要是针对不想以及不愿使用普通 ...

  2. ui-router带参数的路由配置

    ui-router带参数的路由配置 使用ng-route的时候带参数的连接这样配置: $routeProvider.when('item/itemid/:itemid', { templateUrl: ...

  3. Findbugs介绍及使用方法

    1.   简介 Findbugs 是一个静态分析工具,它检查类或者 JAR 文件,将字节码与一组缺陷模式进行对比以发现可能的问题.利用这个工具,就可以在不实际运行程序的情况对软件进行分析.它可以帮助改 ...

  4. HTTP学习补充一

    1 HTTP协议协商 1.1 NPN NPN:Next Protocol Negotiation,是由Google公司开发的用于SPDY进行协议协商扩展. 协商过程: 服务端在收到客户端的client ...

  5. Python之函数与变量

    本节内容 函数介绍及其作用 函数的定义与调用 函数的参数说明 全局变量与局部变量 值传递和引用传递 一.函数的介绍及其作用 编程语言中的函数与数学中的函数是有区别的:数学中的函数有参数(输入),就会有 ...

  6. hdu3635 Dragon Balls(带权并查集)

    /* 题意:有N个城市, 每一个城市都有一个龙珠(编号与城市的编号相同),有两个操作 T A ,B 将标号为A龙珠所在城市的所有的龙珠移动到B龙珠所在城市中! 思路:并查集 (压缩路径的时候将龙珠移动 ...

  7. Docker之Linux Namespace

    Linux Namespace 介绍 我们经常听到说Docker 是一个使用了Linux Namespace 和 Cgroups 的虚拟化工具,但是什么是Linux Namespace 它在Docke ...

  8. SQL Server代理(6/12):作业里的工作流——深入作业步骤

    SQL Server代理是所有实时数据库的核心.代理有很多不明显的用法,因此系统的知识,对于开发人员还是DBA都是有用的.这系列文章会通俗介绍它的很多用法. 如我们在这里系列的前几篇文章所见,SQL ...

  9. C# 通过反射来动态创建泛型类型

    C# 通过反射来动态创建泛型类型与创建普通类型的区别在于:泛型参数的处理 创建泛型类型存在三种情况: 第一种:知道泛型类型,但需要动态指定泛型参数: 第二种:知道泛型参数,但需要动态创建指定参数的泛型 ...

  10. 实现UniqueAttribute唯一性约束-优化版

    我之前就写过一篇<实现UniqueAttribute唯一性约束>,虽然实现了通过调用IsValid方法可以进行唯一性验证,但有一个缺点,那就是耦合度过高,原因是里面的DB上下文对象是直接写 ...