2018-03-19 03:47:14 +08:00
|
|
|
/*
|
|
|
|
code for computing nth catalan number
|
|
|
|
*/
|
2020-05-30 04:23:24 +08:00
|
|
|
#include <stdio.h>
|
2020-06-28 23:25:37 +08:00
|
|
|
long int factorial(int x) // long int for more than 10 factorial
|
2018-03-19 03:47:14 +08:00
|
|
|
{
|
2020-05-30 04:23:24 +08:00
|
|
|
int i;
|
2020-06-28 23:25:37 +08:00
|
|
|
long int fac; // fac stores x factorial
|
2020-05-30 04:23:24 +08:00
|
|
|
fac = x;
|
2020-06-28 23:25:37 +08:00
|
|
|
for (i = 1; i < x; i++) // loop to calculate x factorial
|
2020-05-30 04:23:24 +08:00
|
|
|
{
|
|
|
|
fac = fac * (x - i);
|
|
|
|
}
|
2020-06-28 23:25:37 +08:00
|
|
|
return fac; // returning x factorial
|
2018-03-19 03:47:14 +08:00
|
|
|
}
|
|
|
|
int main()
|
|
|
|
{
|
2020-06-28 23:25:37 +08:00
|
|
|
long int f1, f2, f3; // long int for more than 10 factorial
|
2018-03-19 03:47:14 +08:00
|
|
|
int n;
|
2020-06-28 23:25:37 +08:00
|
|
|
float C; // C is catalan number for n;
|
2020-05-30 04:23:24 +08:00
|
|
|
scanf("%d", &n);
|
|
|
|
f1 = factorial(2 * n);
|
|
|
|
f2 = factorial(n + 1);
|
|
|
|
f3 = factorial(n);
|
2020-06-28 23:25:37 +08:00
|
|
|
C = f1 / (f2 * f3); // formula for catalan number for n
|
2020-05-30 04:23:24 +08:00
|
|
|
printf("%0.2f", C);
|
2018-03-19 03:47:14 +08:00
|
|
|
return 0;
|
|
|
|
}
|