【DP】Table(CF232B)

正题

luogu
CF232B


题目大意

给你一个 n×mn\times mn×m 的网格,问你有多少种放点方案可以满足每个 n×nn\times nn×n 的网格内都恰好有 kkk 个点


解题思路

不难发下,n×nn\times nn×n 的格子往下移一行,新的一行和刚过的一行点的数量一样

那么设 fi,jf_{i,j}fi,j 表示前 iii 行放了 jjj 个点的方案数,然后直接暴力转移即可


code

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define ll long long
#define N 110
#define mod 1000000007
using namespace std;
ll n,m,k,inv[N],fac[N],ifac[N],g[N][N],f[N][N*N];
ll C(ll x,ll y)
{return fac[x]*ifac[x-y]%mod*ifac[y]%mod;
}
ll pw(ll x,ll y)
{ll z=1;while(y){if(y&1)z=z*x%mod;x=x*x%mod;y>>=1;}return z;
}
void pre_work()
{ifac[0]=fac[0]=inv[1]=ifac[1]=fac[1]=1;for(ll i=2;i<=n;++i){inv[i]=mod-mod/i*inv[mod%i]%mod;fac[i]=fac[i-1]*i%mod;ifac[i]=ifac[i-1]*inv[i]%mod;}for(ll i=1;i<=n;++i)for(ll j=0;j<=n;++j)g[i][j]=pw(C(n,j),(m-i+n)/n);//第i行选j个点的方案数,幂为后面一样的行return;
}
int main()
{scanf("%lld%lld%lld",&n,&m,&k);pre_work();f[0][0]=1;for(ll i=1;i<=n;++i)for(ll j=0;j<=k;++j)for(ll l=0;l<=min(j,n);++l)(f[i][j]+=f[i-1][j-l]*g[i][l]%mod)%=mod;printf("%lld",f[n][k]);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/319195.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

枚举子集dp

枚举子集 二进制枚举子集下面代码就是枚举的s的子集&#xff08;二进制状态压缩&#xff09; for(int is;i;i(i-1)&s){//i表示的就是s的子集}枚举所有子集的子集的时间复杂度 比如一个有n个元素构成的集合&#xff0c;子集的数量是2n2^n2n&#xff0c;现要求枚举所有子集的…

数列互质(莫队算法)

数列互质 题目描述 给出一个长度为 n 的数列 { a[1] , a[2] , a[3] , … , a[n] }&#xff0c;以及 m 组询问 ( l[i] , r[i] , k[i])。 求数列下标区间在 [ l[i] , r[i] ] 中有多少数在该区间中的出现次数与 k[i] 互质&#xff08;最大公约数为1&#xff09;。 输入描述: 第一…

P3211-[HNOI2011]XOR和路径【高斯消元】

正题 题目链接:https://www.luogu.com.cn/problem/P3211 题目大意 一个nnn个点mmm条边的无向图&#xff0c;从111到nnn随机游走。求期望路径异或和。 2≤n≤100,1≤m≤1042\leq n\leq 100,1\leq m\leq 10^42≤n≤100,1≤m≤104 解题思路 因为是异或的期望&#xff0c;很难直…

【随机】Ghd(CF364D)

正题 luogu CF364D 题目大意 给你一个大小为n的集合&#xff0c;选择一个至少为一半的子集&#xff0c;另其gcd最大 解题思路 由于数字个数很多&#xff0c;考虑随机 随机选10个数&#xff0c;对于每个数&#xff0c;先处理出约数&#xff0c;然后求出所有数和当前数的gcd&…

ASP.NET Core2读写InfluxDB时序数据库

在我们很多应用中会遇到有一种基于一系列时间的数据需要处理&#xff0c;通过时间的顺序可以将这些数据点连成线&#xff0c;再通过数据统计后可以做成多纬度的报表&#xff0c;也可通过机器学习来实现数据的预测告警。而时序数据库就是用于存放管理这种有着时间顺序数据的&…

Nature 新研究发布,GPT 驱动的机器人化学家能够自行设计和进行实验,这对科研意味着什么?

文章目录 前言揭秘Coscientist不到四分钟&#xff0c;设计并改进了程序能力越大&#xff0c;责任越大 前言 有消息称&#xff0c;AI 大模型 “化学家” 登 Nature 能够自制阿司匹林、对乙酰氨基酚、布洛芬&#xff0c;甚至连复杂的钯催化交叉偶联反应&#xff0c;也能完成。 …

珂朵莉的约数

来源&#xff1a;牛客网&#xff1a; 题目描述 珂朵莉给你一个长为n的序列&#xff0c;有m次查询 每次查询给两个数l,r 设s为区间[l,r]内所有数的乘积 求s的约数个数mod 1000000007 输入描述: 第一行两个正整数n,m 第二行一个长为n的序列 之后m行每行两个数l和r 输出描述…

AtCoder Regular Contest 110 E.Shorten ABC——坑

计数渣渣不会啊 下学期学概率论与数理统计不知道会不会提升数数能力 E.Shorten ABC 当B数组确定后&#xff0c;不难发现就是所问问题即从B序列选出A序列的方案数。 等效于那么从mn中选出sn个小球&#xff0c;我们假设多选的n个小球是一个隔板&#xff0c;隔出数组A&#xff0…

【DP】Rotating Substrings(CF1363F)

正题 luogu CF1363F 题目大意 给你一个字符串&#xff0c;你以旋转其中一个字串&#xff08;将最后一给点移到前面&#xff0c;然后整体向后移一位&#xff09;&#xff0c;问最少要多少布可以到目标字符串 解题思路 设 fi,jf_{i,j}fi,j​ 为 sss 中的前 iii 个字符构成 ttt…

P3348-[ZJOI2016]大森林【LCT】

正题 题目链接:https://www.luogu.com.cn/problem/P3348 题目大意 有nnn棵树开始只有一个编号为111的节点且为标记点。mmm次操作要求支持 在l∼rl\sim rl∼r的树中的标记点下面加入一个新的编号的节点将l∼rl\sim rl∼r的树上的标记点改为xxx&#xff08;如果没有节点xxx就不…

SmartCode 常见问题

SmartCode 能干什么&#xff1f;SmartCode IDataSource -> IBuildTask -> IOutput > Build EverythingSmartCode的执行流是 数据源->构建任务->输出&#xff0c;也就是说应用场景非常广泛。从DB读取数据结构&#xff0c;最终生成整个解决方案代码生成器&#x…

[数论]线性筛——约数个数与约数和

参考博客 参考博客 参考博客 这个讲的挺好 预备知识点&#xff1a; 大于1的数n可以分解质因数&#xff1a; np1a1p2a2p3a3*…*pka n的约数的个数是(a11) * (a21) * (a31)…(ak1) 我们先用线性筛来筛出素数 bool mark[maxn]; int prim[maxn]; int cnt; void initial() {cnt0;f…

F. Paper Grading(Trie树+dfs序+二维数点)

F. Paper Grading 大佬题解 一般关于前缀的问题基本都是Trie树。 首先将所给字符串建立一棵Trie树&#xff0c;Trie能够解决一个字符串在一个字符串集合中出现的次数&#xff0c;而查询前缀次数只需要找到Trie树中所给字符末尾的位置&#xff0c;那么其子树中打标记的次数即前…

AT2164-[AGC006C]Rabbit Exercise【差分,倍增,数学期望】

正题 题目链接:https://www.luogu.com.cn/problem/AT2164 题目大意 nnn只兔子编号为1∼n1\sim n1∼n&#xff0c;第iii只在坐标轴xix_ixi​处。然后mmm次跳跃&#xff0c;每次给出aia_iai​&#xff0c;编号为aia_iai​的兔子会等概率的选取ai−1a_{i-1}ai−1​和ai1a_{i1}ai1…

k-substrings(CF961F)

正题 luogu CF961F 题目大意 给你一个字符串T&#xff0c;对于k1~n/2&#xff0c;找到最长的串s&#xff0c;满足s是T左右各删除k个字符构成的字串t的前缀后缀&#xff08;不能是整个字符串&#xff09; 解题思路 不难发现&#xff0c;k的答案左右各删一个字符必定能得到k1的…

全面支持开源,微软加速 Visual Studio 和 Azure DevOps 云升级

在 2018 微软技术暨生态大会&#xff08;Microsoft Tech Summit&#xff09;上&#xff0c;微软宣布围绕 Visual Studio 和 Visual Studio Code 开发平台提供一系列新功能与服务&#xff0c;并对 Azure DevOps 研发云进行整合升级&#xff0c;通过 Visual Studio 开发平台与微软…

求约数个数的和

今天一下午都在研究约数的各种性质。。。 求约数个数的和可以用线性筛的方式&#xff0c;线性求解的方式&#xff0c;这应该是最快的 [数论]线性筛——约数个数与约数和 除此之外还有代码更简便方法&#xff1a; 对应的例题 方法一&#xff1a; #include <iostream> …

I. Space Station(hash记忆化+dp)

《文章》陆游 文章本天成&#xff0c;妙手偶得之。 粹然无疵瑕&#xff0c;岂复须人为。 君看古彝器&#xff0c;巧拙两无施。 汉最近先秦&#xff0c;固已殊淳漓。 胡部何为者&#xff0c;豪竹杂哀丝。 后夔不复作&#xff0c;千载谁与期&#xff1f; I. Space Station 大佬…

HttpClient参观记:.net core 2.2 对HttpClient到底做了什么?

.net core 于 10月17日发布了 ASP.NET Core 2.2.0 -preview3&#xff0c;在这个版本中&#xff0c;我看到了一个很让我惊喜的新特性&#xff1a;HTTP Client Performance Improvements &#xff0c;而且在Linux上性能提升了60% !之前就一直苦于 HttpClient 的糟糕特性&#xff…

【线段树】Serious Business(CF1648D)

正题 luogu CF1648D 题目大意 有一个 3*n 的矩阵&#xff0c;1,3行没有行走限制&#xff0c;对于第2行&#xff0c;有m个区间&#xff0c;覆盖第 i 个区间有 kik_iki​ 的代价&#xff0c;只有覆盖的位置才能走&#xff0c;让你从 (1,1) 走到 (3,n)&#xff08;只能向下和向右…