16. Nth Catalan Number
The problem can be found at the following link: Question Link
What are the Catalan numbers
The Catalan numbers form a sequence characterized by the following recurrence relationship:
C0 = 1
C1 = 1
C2 = C0 * C1 + C1 * C0
C3 = C0 * C2 + C1 * C1 + C2 * C0
...
...
Ci = C0 * Ci-1 + C1 * Ci-2 + C2 * Ci-3 + ... + Ci-2 * C1 + Ci-1 * C0In this series, each term (C_i) is calculated by combining the previous terms (C_i-1, C_i-2, ...) using multiplicative relationships.
My Approach
To calculate the nth Catalan number, I used dynamic programming.
I iteratively computed the Catalan numbers up to
nusing a bottom-up approach.For each
i from 2 to n, I calculatedc[i]by summing up the products ofc[j]andc[i - 1 - j]for all valid j values.The result is stored in
c[n], which represents the nth Catalan number.
Explanation with Example
For instance, let's take n = 4:
So, the 4th Catalan number is 14.
Time and Auxiliary Space Complexity
Time Complexity: The time complexity of this approach is
O(n^2), where n is the given input.Auxiliary Space Complexity: The auxiliary space complexity is
O(n), as I used an arraycof sizen+1to store intermediate results.
Code (C++)
Contribution and Support
For discussions, questions, or doubts related to this solution, please visit our discussion section. We welcome your input and aim to foster a collaborative learning environment.
If you find this solution helpful, consider supporting us by giving a ⭐ star to the getlost01/gfg-potd repository.
Last updated
Was this helpful?