24h購物| | PChome| 登入
2013-04-17 22:06:50| 人氣827| 回應0 | 上一篇 | 下一篇

[UVA][組合、JAVA大數] 10516 - Another Counting Problem

推薦 0 收藏 0 轉貼0 訂閱站台

Problem H
Another Counting Problem
Input: Standard Input

Output: Standard Output

Tree is an important data structure in Computer Science. Of all trees we work with, Binary Tree is probably the most popular one. A Binary Tree is called Strictly Binary Tree if every nonleaf node in a binary tree has nonempty left and right subtrees. Let us define a Strictly Binary Tree of depth d, as a Strictly Binary Tree that has at least one root to leaf path of length d, and no root to leaf path in that tree is longer than d. So let us use a similar reasoning to define a generalized structure.

A n-ary Tree is called Strictly n-ary Tree if every nonleaf node in a n-ary tree has n children each. a Strictly n-ary Tree of depth d, then can be defined as a Strictly n-ary Tree that has at least one root to leaf path of length d, and no root to leaf path in that tree is longer than d.

Given the value of n and depth d, your task is to find the number of different strictly n-ary trees of depth d.

The figure below shows the 3 different strictly binary trees of depth 2.

Input

Input consists of several test cases. Each test case consists of two integers n (0 < n <= 32), d (0 <= d <= 16). Input is terminated a test case where n=0 and d=0, you must not process this test case.

 

Output

For each test case, print three integers, n, d and the number of different strictly n-ary trees of level d, in a single line. There will be a single space in between two integers of a line. You can assume that you would not be asked about cases where you had to consider trees that may have more than 210 nodes in a level of the tree. You may also find it useful to know that the answer for each test case will always fit in a 200 digit integer.

 

Sample Input                               Output for Sample Input

2 0
2 1
2 2
2 3
3 5
0 0
2 0 1
2 1 1
2 2 3
2 3 21
3 5 58871587162270592645034001

 

 


Problemsetter: Monirul Hasan


dp[i][j] 表示分枝度 i, 深度不超過 j 的種數。

則 dp[i][j] = (dp[i][j-1])^i

解釋為 每一支腳都接深度不超過 j-1, 其方法數是相乘。


import java.util.Scanner;
import java.math.BigInteger;

public class Main {
    static int n, d;
    static BigInteger[][] dp = new BigInteger[35][35];

    static BigInteger get(int n, int d) {
        if (dp[n][d].compareTo(BigInteger.ZERO) > 0)
            return dp[n][d];
        BigInteger tmp = get(n, d - 1);
        tmp = tmp.add(BigInteger.ONE);
        dp[n][d] = tmp.pow(n);
        return dp[n][d];
    }

    public static void main(String[] args) {
        int i, j;
        for (i = 0; i < 35; i++)
            for (j = 0; j < 35; j++)
                dp[i][j] = BigInteger.ZERO;
        for (i = 0; i < 35; i++) {
            dp[i][0] = BigInteger.ONE;
            dp[i][1] = BigInteger.ONE;
        }
        Scanner cin = new Scanner(System.in);
        while (cin.hasNext()) {
            n = cin.nextInt();
            d = cin.nextInt();
            if (n == 0 && d == 0)
                break;
            System.out.printf("%d %d ", n, d);
            if (d >= 2)
                System.out.println(get(n, d).subtract(get(n, d - 1)));
            else
                System.out.println("1");
        }
    };
}

台長: Morris
人氣(827) | 回應(0)| 推薦 (0)| 收藏 (0)| 轉寄
全站分類: 不分類 | 個人分類: UVA |
此分類下一篇:[UVA][數學、N皇后單一快速解] 10094 - Place the Guards
此分類上一篇:[UVA][善用網路] 11028 - Sum of Product

是 (若未登入"個人新聞台帳號"則看不到回覆唷!)
* 請輸入識別碼:
請輸入圖片中算式的結果(可能為0) 
(有*為必填)
TOP
詳全文