0
点赞
收藏
分享

微信扫一扫

杨辉三角的一些性质


杨辉三角的一些性质_杨辉三角


与通项公式的联系:

杨辉三角的一些性质_杭电_02


对于n>=1,适用这个公式

每行的行号为n+1

第n+1行的每一行的数为:C(n,0),C(n,1)……C(n,n)

每个数字等于上一行的左右两个数字之和。可用此性质写出整个杨辉三角。即第n+1行的第i个数等于第n行的第i-1个数和第i个数之和,这也是组合数的性质之一。即 C(n+1,i)=C(n,i)+C(n,i-1)。

例子:

循环多少次?

Problem Description
我们知道,在编程中,我们时常需要考虑到时间复杂度,特别是对于循环的部分。例如,
如果代码中出现
for(i=1;i<=n;i++) OP ;
那么做了n次OP运算,如果代码中出现
fori=1;i<=n; i++)
for(j=i+1;j<=n; j++) OP;
那么做了n*(n-1)/2 次OP 操作。
现在给你已知有m层for循环操作,且每次for中变量的起始值是上一个变量的起始值+1(第一个变量的起始值是1),终止值都是一个输入的n,问最后OP有总共多少计算量。

Input
有T组case,T<=10000。每个case有两个整数m和n,0大于m小于2000,0大于n小于2000.

Output
对于每个case,输出一个值,表示总的计算量,也许这个数字很大,那么你只需要输出除1007留下的余数即可。

Sample Input
2
1 3
2 3

Sample Output
3
3

分析:
这里的n就相当于n,第n行,m相当于第几个数

# include <iostream>
# include <cstdio>

using namespace std;
int a[3000][3000];
int main(){

int m,n,T;
int i,j;


for(i=0;i<2003;i++)
for(j=0;j<=i;j++){
if(j==0||j==i)
a[i][j]=1;
else
a[i][j] = (a[i-1][j-1]+a[i-1][j])%1007;
}

while(scanf("%d",&T)!=EOF){

while(T--){

scanf("%d%d",&m,&n);
printf("%d\n",a[n][m]);//这里结合杨辉三角可知

}

}

return 0;
}


举报

相关推荐

杨辉三角.java

杨辉三角(Java)

杨辉三角算法

leetcode:杨辉三角

杨辉三角规律

杨辉三角(java)

杨辉三角展示

杨辉三角问题

0 条评论