我的加泰罗尼亚数字逻辑有什么问题?

发布于 2024-11-02 00:20:33 字数 878 浏览 5 评论 0原文

我想为加泰罗尼亚数字编写代码。加泰罗尼亚数字的定义如下:

C(n) = 2n C n/(n+1)。但是我不想计算 (2n C n) 我想使用以下事实自下而上地计算加泰罗尼亚数字:

Catalan(n) =    
2n! /n! * n! * (n+1)  

Catalan(n+1) =  
2*(n+1)  
--------------------------- =    
(n+1)! * (n+1)! * ((n+1)+1)  

(2n+2) * (2n+1) * 2n!    
------------------------------- =  
(n+1) * n! * (n+1) * n! * (n+2)    

(2n+2) * (2n+1) * 2n!    
----------------------------------- =    
(n+1) * (n+2) * n! * n! * (n+1)    

(2n+2) * (2n+1)    
--------------- * Catalan(n)      
(n+1) * (n+2)

现在利用上述事实,这是我的以下代码:

int catalan(int n)
{
    if (n == 1)
       return 1 //since c(1)=1 is my base case
    else
       return (((2*n+2) * (2*n+1))/((n+1)*(n+2))) * catalan(n-1)
}

现在,我的问题是为什么上面的代码会这样当我的输入是 4 时,函数返回 12 。它应该返回 14,因为 c(4)=14。

有人可以帮我吗?

I wanted to write a code for Catalan Numbers.Catalan Numbers are defined as follows:

C(n) = 2n C n/(n+1). But instead of computing (2n C n) I wanted to calculate the catalan numbers bottom up using the following facts:

Catalan(n) =    
2n! /n! * n! * (n+1)  

Catalan(n+1) =  
2*(n+1)  
--------------------------- =    
(n+1)! * (n+1)! * ((n+1)+1)  

(2n+2) * (2n+1) * 2n!    
------------------------------- =  
(n+1) * n! * (n+1) * n! * (n+2)    

(2n+2) * (2n+1) * 2n!    
----------------------------------- =    
(n+1) * (n+2) * n! * n! * (n+1)    

(2n+2) * (2n+1)    
--------------- * Catalan(n)      
(n+1) * (n+2)

Now utilizing the above fact this is my following code:

int catalan(int n)
{
    if (n == 1)
       return 1 //since c(1)=1 is my base case
    else
       return (((2*n+2) * (2*n+1))/((n+1)*(n+2))) * catalan(n-1)
}

Now,my question is why does the above function return 12 when my input is 4 .It should return 14 because c(4)=14.

Can anyone help me, please?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

你在看孤独的风景 2024-11-09 00:20:33

尽管 C(n) 的原始表达式可能是错误的,但实际的重复

在此处输入图像描述

正确

您可以进一步简化为

在此处输入图像描述

但这为您提供了 C(n+1)C(n) 而言。您想要的是用 C(n-1) 表示的 C(n)。插入n-1即可得到

在此处输入图像描述

另请注意,为了防止整数除法会截断结果,您需要先乘法,然后除法。

int catalan(int n) {
  if (n == 1)
    return 1; 
  else
    return 2 * (2*n - 1) * catalan(n-1) / (n+1);
}

编辑:如果 在此处输入图像描述 的值需要经常使用而不仅仅是计算一次,使用记忆化可能是个好主意,以避免多次计算它们。

此外,请注意,由于增长率较大,加泰罗尼亚数字很快就会溢出 C 具有的任何预定义整数数据类型。

Even though the original expression for C(n) might be wrong, the actual recurrence

enter image description here

is correct.

You can further simplify that to

enter image description here

But that gives you C(n+1) in terms of C(n). What you want is C(n) in terms of C(n-1). Plug in n-1 to get

enter image description here

Also note that in order to prevent the integer division from truncating your result, you need to multiply first and then divide.

int catalan(int n) {
  if (n == 1)
    return 1; 
  else
    return 2 * (2*n - 1) * catalan(n-1) / (n+1);
}

EDIT: if the values of the enter image description here need to be used frequently and not just calculated once, it's probably a good idea to use memoization, to avoid calculating them more than once.

Additionally, notice that due to the large growth rate, the Catalan numbers quickly overflow any of the predefined integer data types C has.

小伙你站住 2024-11-09 00:20:33

根据http://en.wikipedia.org/wiki/Catalan_number,递归公式为:

<代码>C(n+1)=2(2n+1)/(n+1) * C(n) 或C(n)=2(2(n-1)+1) /n * C(n-1)

我认为您已经忘记了从 C(n+1)C(n) 的转换。

According to http://en.wikipedia.org/wiki/Catalan_number the recurrence formula is:

C(n+1)=2(2n+1)/(n+1) * C(n) or C(n)=2(2(n-1)+1)/n * C(n-1)

I think you have forgotten this transformation from C(n+1) to C(n).

月寒剑心 2024-11-09 00:20:33

你的公式有错误。您的公式用于计算 c(n+1) 但您的输入是 n。这可以通过在计算中使用 n 之前将其值减一来解决:

int catalan(int n)
{
    if (n == 1)
       return 1 //since c(1)=1 is my base case
    else
       n=n-1
       return (((2*n+2) * (2*n+1))/((n+1)*(n+2))) * catalan(n)
}

编辑: 正如 abeln 所指出的,上面的代码将由于整数除法丢弃余数而失败。请改用下面的代码:

int catalan(int n)
{
    if (n == 1)
       return 1 //since c(1)=1 is my base case
    else
       n=n-1
       return ((catalan(n) * (2*n+2) * (2*n+1))/((n+1)*(n+2)))
}

There is an error in your formula. Your formula is for calculating c(n+1) yet your input is n. This can be fixed by decreasing the value of n by one before using it in the calculation:

int catalan(int n)
{
    if (n == 1)
       return 1 //since c(1)=1 is my base case
    else
       n=n-1
       return (((2*n+2) * (2*n+1))/((n+1)*(n+2))) * catalan(n)
}

Edit: As pointed out by abeln, the code above will fail due to integer division dropping the remainder. Use the code below instead:

int catalan(int n)
{
    if (n == 1)
       return 1 //since c(1)=1 is my base case
    else
       n=n-1
       return ((catalan(n) * (2*n+2) * (2*n+1))/((n+1)*(n+2)))
}
谎言月老 2024-11-09 00:20:33

当您从数学表达式转向代码时,您会在 Catalan() 部分中隐式地将 n 替换为 n-1,但在表达式本身中则不然。因此,您要计算值 N 的乘数并将其乘以 C(N-1)。尝试用 N-1 代替方程中的 N,结果是:

int catalan(int n)
{
    if (n == 1)
       return 1 //since c(1)=1 is my base case
    else
       return (((2*n) * (2*n-1))/((n)*(n+1))) * catalan(n-1)
}

When you go from the mathematical expression to code, you are implicitly replacing n with n-1 in the Catalan() parts, but not in the expression itself. So you are computing the multiplier for value N and multiplying it by C(N-1). Try substituting N-1 for N in your equation, which leads to:

int catalan(int n)
{
    if (n == 1)
       return 1 //since c(1)=1 is my base case
    else
       return (((2*n) * (2*n-1))/((n)*(n+1))) * catalan(n-1)
}
杀お生予夺 2024-11-09 00:20:33

在您的公式中,

         (2n)!
C(n) = ----------------
        (n+1)! * n! * n!

实际上加泰罗尼亚数字的定义是

         (2n)!
C(n) = ----------------
        (n+1)! * n!

,即分母上的阶乘太多

In your formula, you have

         (2n)!
C(n) = ----------------
        (n+1)! * n! * n!

when in fact the Catalan Numbers are defined as

         (2n)!
C(n) = ----------------
        (n+1)! * n!

i.e. you have one factorial on the denominator too much

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文