📜  Bell Numbers(划分集合的方法数)

📅  最后修改于: 2021-09-22 10:06:00             🧑  作者: Mango

给定一组 n 个元素,找出划分它的多种方法。
例子:

Input:  n = 2
Output: Number of ways = 2
Explanation: Let the set be {1, 2}
            { {1}, {2} } 
            { {1, 2} }

Input:  n = 3
Output: Number of ways = 5
Explanation: Let the set be {1, 2, 3}
             { {1}, {2}, {3} }
             { {1}, {2, 3} }
             { {2}, {1, 3} }
             { {3}, {1, 2} }
             { {1, 2, 3} }. 

上述问题的解决方案是Bell Number。
什么是铃号?
S(n, k)是将 n 个元素划分为 k 个集合的总数。第 n 个贝尔数的值是 k = 1 到 n 时 S(n, k) 的总和。
Bell(n) = \sum_{k=0}^{n}S(n,k)
S(n, k) 的值可以递归定义为, S(n+1, k) = k*S(n, k) + S(n, k-1)
上面的递归公式是如何工作的?
当我们向 k 个分区添加第 (n+1) 个元素时,有两种可能性。
1) 它作为单个元素集添加到现有分区,即 S(n, k-1)
2) 将其添加到每个分区的所有集合中,即k*S(n, k)
S(n, k) 称为第二类斯特林数
前几个贝尔数是 1, 1, 2, 5, 15, 52, 203, ….
计算第 n 个贝尔数的简单方法是对 k = 1 到 n 逐一计算 S(n, k) 并返回所有计算值的总和。请参阅此以计算 S(n, k)。
更好的方法是使用钟形三角形。下面是前几个贝尔数的示例贝尔三角形。

1
1 2
2 3 5
5 7 10 15
15 20 27 37 52

三角形是使用以下公式构建的。

// If this is first column of current row 'i'
If j == 0
   // Then copy last entry of previous row
   // Note that i'th row has i entries
   Bell(i, j) = Bell(i-1, i-1) 

// If this is not first column of current row
Else 
   // Then this element is sum of previous element 
   // in current row and the element just above the
   // previous element
   Bell(i, j) = Bell(i-1, j-1) + Bell(i, j-1)

解释
然后 Bell(n, k) 计算集合 {1, 2, …, n + 1} 的分区数,其中元素 k + 1 是其集合中可以单独存在的最大元素。
例如 Bell(3, 2) 是 3,它是 {1, 2, 3, 4} 的分区数,其中 3 是最大的单例元素。有三个这样的分区:

{1}, {2, 4}, {3}
    {1, 4}, {2}, {3}
    {1, 2, 4}, {3}. 

以下是上述递归公式的基于动态规划的实现。

C++
// A C++ program to find n'th Bell number
#include
using namespace std;
 
int bellNumber(int n)
{
   int bell[n+1][n+1];
   bell[0][0] = 1;
   for (int i=1; i<=n; i++)
   {
      // Explicitly fill for j = 0
      bell[i][0] = bell[i-1][i-1];
 
      // Fill for remaining values of j
      for (int j=1; j<=i; j++)
         bell[i][j] = bell[i-1][j-1] + bell[i][j-1];
   }
   return bell[n][0];
}
 
// Driver program
int main()
{
   for (int n=0; n<=5; n++)
      cout << "Bell Number " << n << " is "
           << bellNumber(n) << endl;
   return 0;
}


Java
// Java program to find n'th Bell number
import java.io.*;
 
class GFG
{
    // Function to find n'th Bell Number
    static int bellNumber(int n)
    {
        int[][] bell = new int[n+1][n+1];
        bell[0][0] = 1;
         
        for (int i=1; i<=n; i++)
        {
            // Explicitly fill for j = 0
            bell[i][0] = bell[i-1][i-1];
  
            // Fill for remaining values of j
            for (int j=1; j<=i; j++)
                bell[i][j] = bell[i-1][j-1] + bell[i][j-1];
        }
         
        return bell[n][0];
    }
     
    // Driver program
    public static void main (String[] args)
    {
        for (int n=0; n<=5; n++)
            System.out.println("Bell Number "+ n +
                            " is "+bellNumber(n));
    }
}
 
// This code is contributed by Pramod Kumar


Python3
# A Python program to find n'th Bell number
 
def bellNumber(n):
 
    bell = [[0 for i in range(n+1)] for j in range(n+1)]
    bell[0][0] = 1
    for i in range(1, n+1):
 
        # Explicitly fill for j = 0
        bell[i][0] = bell[i-1][i-1]
 
        # Fill for remaining values of j
        for j in range(1, i+1):
            bell[i][j] = bell[i-1][j-1] + bell[i][j-1]
 
    return bell[n][0]
 
# Driver program
for n in range(6):
    print('Bell Number', n, 'is', bellNumber(n))
 
# This code is contributed by Soumen Ghosh


C#
// C# program to find n'th Bell number
using System;
 
class GFG {
     
    // Function to find n'th
    // Bell Number
    static int bellNumber(int n)
    {
        int[,] bell = new int[n + 1,
                              n + 1];
        bell[0, 0] = 1;
         
        for (int i = 1; i <= n; i++)
        {
             
            // Explicitly fill for j = 0
            bell[i, 0] = bell[i - 1, i - 1];
 
            // Fill for remaining values of j
            for (int j = 1; j <= i; j++)
                bell[i, j] = bell[i - 1, j - 1] +
                             bell[i, j - 1];
        }
         
        return bell[n, 0];
    }
     
    // Driver Code
    public static void Main ()
    {
        for (int n = 0; n <= 5; n++)
            Console.WriteLine("Bell Number "+ n +
                              " is "+bellNumber(n));
    }
}
 
// This code is contributed by nitin mittal.


PHP


Javascript


输出:

Bell Number 0 is 1
Bell Number 1 is 1
Bell Number 2 is 2
Bell Number 3 is 5
Bell Number 4 is 15
Bell Number 5 is 52

如果您希望与专家一起参加现场课程,请参阅DSA 现场工作专业课程学生竞争性编程现场课程