我有一个一维数组,其中包含pascal三角形的值,从左到右计算数字。
int pascal[10] = { 1, 1, 1, 1, 2, 1, 1, 3, 3, 1 };
如何使用它快速找到两个数字的组合?
e.g。找到3选择1,我会在数组中查找答案3.如何正确计算我需要查看的索引?
如果我想继续构建Pascal的三角形,如何在不进行树递归的情况下使用此数组来构建它?类似于递归关系的东西
答案 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