Acwing.885 求组合数l

发布于:2023-09-14 ⋅ 阅读:(112) ⋅ 点赞:(0)

题目

给定n组询问,每组询问给定两个整数a,b,请你输出C mod (10°+7)的值。

输入格式

第—行包含整数n。
接下来n行,每行包含—组a和b。

输出格式

共n行,每行输出一个询问的解。

数据范围

1≤n ≤ 10000,1<b<a ≤2000

  • 输入样例:
3
3 1
5 3
2 2
  • 输出样例:
3
10
1

代码

#include <iostream>
#include <algorithm>
using namespace std;
const int N = 2010,mod - 1e9 + 7;
int c[N][N];
void init()
{
	for (int i - 0; i < N; i + )
		for (int j - 0; j<=i; j ++ )
			if (!j) c[i][j]= i;
			else c[i][j]=(c[i- 1][j] +c[i - 1][j - 1])% mod;
}

int main()
{
	init();
	int n;
	scanf(%d",&n) ;
	while (n -- )
	{
		int a, b;
		scanf("%d%d" , &a,&b);
		printf("%d\n", c[a][b]);
	}
return 0;
}

思路

这道题运用到了动态规划的思想,同时也需要数学推到下图式子,即可解决。在这里插入图片描述

本文含有隐藏内容,请 开通VIP 后查看

网站公告

今日签到

点亮在社区的每一天
去签到