http://acm.hdu.edu.cn/showproblem.php?pid=3723
需要用到大整数 终于用java AC了
此题为经典 catalan 问题的变形
如果问题中的路径只能向上和向下的话就变成了 catalan 了,既然向上和向下的个数相等
枚举向上和向下的个数 每次枚举和剩下的向前状态个数进行组合 即可
代码:
import java.util.*;
import java.math.BigInteger;
import java.math.BigDecimal;
;
public class Main {
public static void main(String[] args) {
int N = 5005;
BigInteger MOD = BigInteger.ONE;
BigInteger k = BigInteger.TEN;
for (int i = 0; i < 100; ++i) {
MOD = MOD.multiply(k);
}
BigInteger[] catalan = new BigInteger[N];
catalan[0] = BigInteger.ONE;
for (int i = 1; i < N; ++i) {
catalan[i] = catalan[i - 1].multiply(BigInteger.valueOf(4 * i - 2));
catalan[i] = catalan[i].divide(BigInteger.valueOf(i + 1));
}
BigInteger[] C = new BigInteger[N * 2];
Scanner in = new Scanner(System.in);
int n;
while (in.hasNext()) {
n = in.nextInt();
BigInteger ans = BigInteger.ZERO;
C[0] = BigInteger.ONE;
for (int i = 1; i <= n; ++i) {
C[i] = C[i - 1].multiply(BigInteger.valueOf(n - i + 1));
C[i] = C[i].divide(BigInteger.valueOf(i));
}
for (int i = 0; i <= n / 2; ++i) {
BigInteger tmp = C[2 * i];
tmp = tmp.multiply(catalan[i]);
ans = ans.add(tmp);
}
ans = ans.mod(MOD);
System.out.println(ans);
}
}
}