zoukankan      html  css  js  c++  java
  • hdu 3723 Delta Wave 夜

    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);
    		}
    	}
    
    }
    
  • 相关阅读:
    PHP5.5新特性
    并发导论【转】
    Redis常用数据结构和操作
    git常用命令【转】
    curl 的用法指南
    pycurl模块
    单点登陆
    MySql 里的IFNULL、NULLIF和ISNULL用法
    Mysql coalesce()函数认识和用法
    python文件操作
  • 原文地址:https://www.cnblogs.com/liulangye/p/2748720.html
Copyright © 2011-2022 走看看