P2822 组合数问题

P2822 组合数问题

  • 标签:NOIp提高组 2016 云端↑
  • 难度: 普及+/提高
  • 时空限制: 1s / 512MB

题目描述

组合数表示的是从n个物品中选出m个物品的方案数。举个例子,从(1,2,3) 三个物品中选择两个物品可以有(1,2),(1,3),(2,3)这三种选择方法。根据组合数的定 义,我们可以给出计算组合数的一般公式:

其中n! = 1 × 2 × · · · × n

小葱想知道如果给定n,m和k,对于所有的0 <= i <= n,0 <= j <= min(i,m)有多少对 (i,j)满足是k的倍数。

输入输出格式

输入格式:

第一行有两个整数t,k,其中t代表该测试点总共有多少组测试数据,k的意义见 【问题描述】。

接下来t行每行两个整数n,m,其中n,m的意义见【问题描述】。

输出格式:

t行,每行一个整数代表答案。

输入输出样例

输入样例#1:

1 2
3 3

输出样例#1:

1

输入样例#2:

2 5
4 5
6 7

输出样例#2:

0
7

说明

【样例1说明】

在所有可能的情况中,只有是2的倍数。

【子任务】

思路分析:

这个题第一反应50分稳了。打打暴力折腾50分出来。n=1的点AC其他TLE...

样例一好像没什么用处。。。所以看看样例二能搞出什么东西来。

手推一下样例二:

\begin{matrix}
C^0_0&&&&&\\
C^0_1&C^1_1&&&&\\
C^0_2&C^1_2&C^2_2&&&\\
C^0_3&C^1_3&C^2_3&C^3_3&&\\
C^0_4&C^1_4&C^2_4&C^3_4&C^4_4&\\
C^0_5&C^1_5&C^2_5&C^3_5&C^4_5&C^5_5
\end{matrix}

套一下公式。

忽略m或n等于0的情况,这个时候组合数无意义。

结合上面的矩阵:

\begin{matrix}
1&0&0&0&0&0\\
2&1&0&0&0&0\\
3&3&1&0&0&0\\
4&6&4&1&0&0\\
5&10&10&5&1&0\\
6&15&20&15&6&1
\end{matrix}

可以看出这是一个杨辉三角。杨辉三角的一般递推式:

\begin{equation*}f[i][j]=f[i-1][j-1]+f[i-1][j]\end{equation*}

杨辉三角的初始化:

\begin{equation*}f[i][1]=i,f[i][i]=1\end{equation*}

时间: 2024-08-29 05:52:54

P2822 组合数问题的相关文章

做题记录:P2822 组合数问题

P2822 组合数问题 /*思路:组合数就是杨辉三角,那么我们只要构造一个杨辉三角就行了. 记得要取模,不然会爆.然后,再用二维前缀和统计各种情况下组合数是k的 倍数的方案数.询问时直接O(1)输出即可.*/ #include<iostream> #include<cstdio> #include<fstream> #include<algorithm> #include<string> #include<sstream> #incl

Luogu P2822 组合数问题(前缀和)

P2822 组合数问题 题意 题目描述 组合数\(C_n^m\)表示的是从\(n\)个物品中选出\(m\)个物品的方案数.举个例子,从\((1,2,3)\)三个物品中选择两个物品可以有\((1,2),(1,3),(2,3)\)这三种选择方法.根据组合数的定义,我们可以给出计算组合数\(C_n^m\)的一般公式: \[C_n^m=\frac{n!}{m!(n-m)!}\] 其中\(n!=1\times 2\times \cdots \times n\):特别地,定义\(0!=1\). 小葱想知道如

洛谷——P2822 组合数问题

https://www.luogu.org/problem/show?pid=2822 题目描述 组合数C_n^mC?n?m??表示的是从n个物品中选出m个物品的方案数.举个例子,从(1,2,3) 三个物品中选择两个物品可以有(1,2),(1,3),(2,3)这三种选择方法.根据组合数的定 义,我们可以给出计算组合数的一般公式: C_n^m=\frac{n!}{m!(n - m)!}C?n?m??=?m!(n−m)!??n!?? 其中n! = 1 × 2 × · · · × n 小葱想知道如果给

组合数问题

组合数公式: 计算组合数的递推方法: C[i, j] := C[i - 1, j] + C[i - 1, j - 1]  (0 < i ≤ j ≤ m ≤ n) 与杨辉三角在形式上一致. 代码: for (int i = 1; i <= n; i++) { c[i][1] = i % k; c[i][i] = 1; // 预处理 } for (int i = 2; i <= n; i++) for (int j = 2; j <= i - 1; j++) // 递推 c[i][j]

LuoguP2822 组合数问题(组合数,二维前缀和)

P2822 组合数问题 输入输出样例 输入样例#1: 复制 1 2 3 3 输出样例#1: 复制 1 输入样例#2: 复制 2 5 4 5 6 7 输出样例#2: 复制 0 7 说明 [样例1说明] 在所有可能的情况中,只有C_2^1 = 2C21?=2是2的倍数. [子任务] #include<bits/stdc++.h> #define N 2001 #define ll long long using namespace std; ll n,m,t,k,ans,cnt; ll C[N+5

AC日记——组合数问题 落谷 P2822 noip2016day2T1

题目描述 组合数表示的是从n个物品中选出m个物品的方案数.举个例子,从(1,2,3) 三个物品中选择两个物品可以有(1,2),(1,3),(2,3)这三种选择方法.根据组合数的定 义,我们可以给出计算组合数的一般公式: 其中n! = 1 × 2 × · · · × n 小葱想知道如果给定n,m和k,对于所有的0 <= i <= n,0 <= j <= min(i,m)有多少对 (i,j)满足是k的倍数. 输入输出格式 输入格式: 第一行有两个整数t,k,其中t代表该测试点总共有多少

[NOIP2016提高组]组合数问题

题目:UOJ#263.洛谷P2822.Vijos P2006.codevs5947. 题目大意:t组数据,每次给你n和m$\leq 2000$,求对于所有的$(0\leq i\leq n)$,$(0\leq j\leq m)$的(i,j),有多少对满足$C^j_i\equiv 0(mod\ k)$. 解题思路:此题是一道数论题.首先,组合数有一个递推公式:$C^m_n=C^m_{n-1}+C^{m-1}_n$,这其实和杨辉三角的递推公式是一样的.那么我们可以预处理出所有的组合数,然后对于每一个问

[Shoi2017]组合数问题 BZOJ4870

这道题可以根据组合数的实际意义来理解,就是从n*k个物品中选择除k余r个物品的方案数,那么就可以得到用f[i][j]表示在前i个物品中,选择j个物品的方案数,其中j是对k取模后的结果,那么f[i][j]=f[i-1][j](在第i为不取)+f[i-1][(j-1+k)%k](在第i为取),可以发现,第i位只与i-1位有关系那么久可以用矩阵快速幂优化, 在做矩阵乘法的时候,要特别注意矩阵乘特别容易爆int,所以矩阵数组要开成long long 另外这道题还有一个坑点,就是当k=1,r=0是,转移到

1056. 组合数的和

1056. 组合数的和(15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 给定N个非0的个位数字,用其中任意2个数字都可以组合成1个2位的数字.要求所有可能组合出来的2位数字的和.例如给定2.5.8,则可以组合出:25.28.52.58.82.85,它们的和为330. 输入格式: 输入在一行中先给出N(1<N<10),随后是N个不同的非0个位数字.数字间以空格分隔. 输出格式: 输出所有可能组合出来的2