从pascals三角形中检索值

时间:2016-10-31 16:37:36

标签: arrays combinations pascals-triangle

我有一个一维数组,其中包含pascal三角形的值,从左到右计算数字。

int pascal[10] = { 1, 1, 1, 1, 2, 1, 1, 3, 3, 1 };

如何使用它快速找到两个数字的组合?

e.g。找到3选择1,我会在数组中查找答案3.如何正确计算我需要查看的索引?

如果我想继续构建Pascal的三角形,如何在不进行树递归的情况下使用此数组来构建它?类似于递归关系的东西

1 个答案:

答案 0 :(得分:1)

如果您坚持使用数组而不是通过公式计算它,那么您可以使用以下(C#示例):

int Choose_N_over_K(int N, int K)
{
    int[] pascal  = new[] { 1, 1, 1, 1, 2, 1,1, 3, 3, 1, 1,4,6,4,1};    
    var index = (N * (N + 1) / 2 +  K  );
    return (pascal[index]);
}


void Main()
{
        Console.WriteLine(Choose_N_over_K(4,2));
}

给予(例如4比2):

6

我们只是根据以下事实计算数组中的索引:三角形中的每一行都有一个元素而不是前一行我们知道如何对数字1..N求和:

// 0: 1  start index 0
// 1: 1 1  start index 1
// 2: 1 2 1  start index 3 
// 3: 1 3 3 1 start index 6
// 4: 1 4 6 4 1 start index 10