微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

形成山脉的方法数

如何解决形成山脉的方法数

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

形成“山脉”的方法数,其中 n 个上行和 n 个下行都保持在原始线以上。

enter image description here

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

public int countMountainRanges(int n) {

}

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

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

解决方法

F(n) = F(n-1) + F(n-2) 是第 n 个斐波那契数的公式。另一方面,第 n 个加泰罗尼亚数由 (2n select 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;
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。