zoukankan      html  css  js  c++  java
  • Train Problem II

    As we all know the Train Problem I, the boss of the Ignatius Train Station want to know if all the trains come in strict-increasing order, how many orders that all the trains can get out of the railway. 

    InputThe input contains several test cases. Each test cases consists of a number N(1<=N<=100). The input is terminated by the end of file. 
    OutputFor each test case, you should output how many ways that all the trains can get out of the railway. 
    Sample Input

    1
    2
    3
    10

    Sample Output

    1
    2
    5
    16796
    
    
            
     

    Hint

    The result will be very large, so you may not process it by 32-bit integers.
    #include<iostream>
    #include<cstdio>
    #include<cstring>
    #include<string>
    #include<set>
    #include<vector>
    #include<stack>
    #include<queue>
    #include<algorithm>
    #include<cstdio>
    #include<algorithm>
    #include<functional>
    #include<sstream>
    using namespace std;
    int a[105][105];    //大数卡特兰数
    int b[105];         //卡特兰数的长度
    
    void catalan()  //求卡特兰数
    {
        int i, j, len, carry, temp;
        a[1][0] = b[1] = 1;
        len = 1;
        for (i = 2; i <= 100; i++)
        {
            for (j = 0; j < len; j++)    //乘法
                a[i][j] = a[i - 1][j] * (4 * (i - 1) + 2);
            carry = 0;
            for (j = 0; j < len; j++)    //处理相乘结果
            {
                temp = a[i][j] + carry;
                a[i][j] = temp % 10;
                carry = temp / 10;
            }
            while (carry)    //进位处理
            {
                a[i][len++] = carry % 10;
                carry /= 10;
            }
            carry = 0;
            for (j = len - 1; j >= 0; j--) //除法
            {
                temp = carry * 10 + a[i][j];
                a[i][j] = temp / (i + 1);
                carry = temp % (i + 1);
            }
            while (!a[i][len - 1])     //高位零处理
                len--;
            b[i] = len;
        }
    }
    
    int main()
    {
        int i, n;
        catalan();
        while (scanf("%d", &n) != EOF)
        {
            for (i = b[n] - 1; i >= 0; i--)
            {
                printf("%d", a[n][i]);
            }
            printf("
    ");
        }
    
        return 0;
    }
  • 相关阅读:
    [技巧] 使用Word2010直接编辑、发布博客→博客园cnblogs
    POJ 1201 Intervals【差分约束】
    HDU 2896 病毒侵袭【AC自动机】
    opengl中的gluOrtho2D【转】
    【转】x86和x64的含义和区别
    POJ 1704 Georgia and Bob【Nim博弈】
    POJ 1947 Rebuilding Roads【树状DP】
    POJ 3207/ POJ 3678 【2SAT】
    POJ 1067 取石子游戏【威佐夫博奕】
    apache+webdav的安装配置
  • 原文地址:https://www.cnblogs.com/edych/p/7264006.html
Copyright © 2011-2022 走看看