1
这题第一反应是搜索,不过看到方案数的范围就知道肯定超时。因为每种方案都是一种排列组合,于是直觉就想到了杨辉三角,索性手写了几个样例,把较小的几种方案列出来,果然找到了规律。
规律:(n,m)方案数 ps:n,m满足对称性
(1,1) (1,2) (1,3) (1,4) (1,5) (1,6)
1 2 3 4 5 6
(2,2) (2,3) (2,4) (2,5) (2,6)
1 3 6 10 15
(3,3) (3,4) (3,5) (3,6)
1 4 10 20
(4,4) (4,5) (4,6)
1 5 15
(5,5) (5,6)
1 6
(6,6)
1
很显然,方案数就是一个倒置的杨辉三角。a[i][j]=a[i-1][j-1]+a[i][j-1]
#include<stdio.h>
#include<stdlib.h>
long long a[1005][1005];
int main()
{
int t,n,m,i,j;
for(i=0;i<=1000;i++){
a[0][i]=1;
}
for(i=1;i<=1000;i++){
for(j=i;j<=1000;j++){
a[i][j]=a[i-1][j-1]+a[i][j-1];
if(a[i][j]>=1000000007) a[i][j]%=1000000007;
}
}
scanf("%d",&t);
while(t--){
scanf("%d%d",&n,&m);
if(n<m) printf("%lld\n",a[n][m]);
else printf("%lld\n",a[m][n]);
}
return 0;
}