【问题标题】:Number of ways to form a mountain ranges形成山脉的方法数
【发布时间】:2021-07-11 16:02:27
【问题描述】:

我正在研究加泰罗尼亚数字的应用:

形成一个“山脉”的方法的数量,其中 n 个上冲程和 n 个下冲程都保持在原线之上。

现在给定一个数字 n,找出山脉的数量。

public int countMountainRanges(int n) {

}

我们可以在这里使用什么逻辑或公式来获取输入n的方式数。

我尝试了公式 F(n) = F(n-1) + F(n-2),但在这种情况下它不起作用。

【问题讨论】:

标签: java algorithm catalan


【解决方案1】:

F(n) = F(n-1) + F(n-2) 是第 n 个斐波那契数的公式。另一方面,第 n 个加泰罗尼亚数由 (2n choose n) / (n + 1) 给出。

public static int countMountainRanges(int n) {
    return choose(2 * n , n) / (n + 1);
}
private static int choose(int n, int k){
    int res = 1;
    k = Math.min(k, n - k);
    for (int i = 0; i < k; i++) {
        res = res * (n - i) / (i + 1);
    }
    return res;
}

【讨论】:

  • 谢谢,你能告诉我这个逻辑是如何解决给定问题的吗?只是想了解如果我在未来看到类似的问题,我需要遵循什么方法。
  • @learner 你可以看看维基百科页面:en.wikipedia.org/wiki/Catalan_number#Proof_of_the_formula
  • 你能解释一下Math.min(k, n - k)为什么我们需要min以及为什么n-k。然后res * (n - i) / (i + 1).
  • @learner n 选择 k 等于 n 选择 (n-k),因此该行选择执行的次数最少
  • @lierwu,抱歉,是 6 而不是 10。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2018-02-04
  • 2018-09-09
相关资源
最近更新 更多