LINK:CountTables

神题!

首先单独考虑行不同的情况

设\(f_i\)表示此时有i列且 行都不同.

那么显然有 \(f_i=(c^i)^\underline{n}\)

考虑设\(g_i\)表示此时有i列且 行列都不同.

考虑将\(g_i\)和\(f_i\)联系起来.

那么对于 \(f_m\) 考虑其有k列是本质不同的

那么有m-k列重复出现的 考虑把这m-k列给缩起来就变成了 n行k列 且行列都不同的矩阵了.

而且可以发现对于n行k列 且行列都不同的矩阵和有k列本质不同且不讲究分配顺序下是一一映射的关系.

那么有 \(f_m=\sum_{k=0}^m\begin {Bmatrix} m \\ k\end {Bmatrix}\cdot g_k\)

然后直接斯特林反演.(和二项式反演似乎差不多.

\(g_m=\sum_{k=0}^m(-1)^{m-k}\left[\begin{matrix}m\\k\end{matrix}\right]f_k\)

然后就做完了 复杂度n^2.

code
  1. //#include<bits/stdc++.h>
  2. #include<iostream>
  3. #include<cstdio>
  4. #include<ctime>
  5. #include<cctype>
  6. #include<queue>
  7. #include<deque>
  8. #include<stack>
  9. #include<iostream>
  10. #include<iomanip>
  11. #include<cstdio>
  12. #include<cstring>
  13. #include<string>
  14. #include<ctime>
  15. #include<cmath>
  16. #include<cctype>
  17. #include<cstdlib>
  18. #include<queue>
  19. #include<deque>
  20. #include<stack>
  21. #include<vector>
  22. #include<algorithm>
  23. #include<utility>
  24. #include<bitset>
  25. #include<set>
  26. #include<map>
  27. #define ll long long
  28. #define db double
  29. #define INF 10000000000000000ll
  30. #define inf 1000000000
  31. #define ldb long double
  32. #define pb push_back
  33. #define put_(x) printf("%d ",x);
  34. #define get(x) x=read()
  35. #define gt(x) scanf("%d",&x)
  36. #define gi(x) scanf("%lf",&x)
  37. #define put(x) printf("%d\n",x)
  38. #define putl(x) printf("%lld\n",x)
  39. #define rep(p,n,i) for(RE int i=p;i<=n;++i)
  40. #define go(x) for(int i=lin[x],tn=ver[i];i;tn=ver[i=nex[i]])
  41. #define fep(n,p,i) for(RE int i=n;i>=p;--i)
  42. #define vep(p,n,i) for(RE int i=p;i<n;++i)
  43. #define pii pair<int,int>
  44. #define mk make_pair
  45. #define RE register
  46. #define P 1000000007ll
  47. #define gf(x) scanf("%lf",&x)
  48. #define pf(x) ((x)*(x))
  49. #define uint unsigned long long
  50. #define ui unsigned
  51. #define EPS 1e-10
  52. #define sq sqrt
  53. #define S second
  54. #define F first
  55. #define mod 1000000007
  56. using namespace std;
  57. char *fs,*ft,buf[1<<15];
  58. inline char gc()
  59. {
  60. return (fs==ft&&(ft=(fs=buf)+fread(buf,1,1<<15,stdin),fs==ft))?0:*fs++;
  61. }
  62. inline int read()
  63. {
  64. RE int x=0,f=1;RE char ch=gc();
  65. while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=gc();}
  66. while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=gc();}
  67. return x*f;
  68. }
  69. const int MAXN=4010;
  70. int n,m,c;
  71. int f[MAXN];
  72. int s[MAXN][MAXN];
  73. inline int ksm(int b,int p)
  74. {
  75. int cnt=1;
  76. while(p)
  77. {
  78. if(p&1)cnt=(ll)cnt*b%mod;
  79. b=(ll)b*b%mod;p=p>>1;
  80. }
  81. return cnt;
  82. }
  83. class CountTables
  84. {
  85. public:
  86. //freopen("1.in","r",stdin);
  87. inline int howMany(int n,int m,int c){
  88. s[0][0]=1;
  89. rep(1,m,i)rep(1,i,j)s[i][j]=(s[i-1][j-1]+(i-1)*(ll)s[i-1][j])%mod;
  90. rep(1,m,i)
  91. {
  92. int ww=ksm(c,i);f[i]=1;
  93. for(int j=ww-n+1;j<=ww;++j)f[i]=(ll)f[i]*j%mod;
  94. }
  95. //put(f[m]);
  96. int ans=0;
  97. rep(0,m,k)
  98. {
  99. int op=((m-k)&1)?-1:1;
  100. ans=(ans+op*s[m][k]*(ll)f[k])%mod;
  101. }
  102. ans=(ans+mod)%mod;
  103. return ans;
  104. }
  105. };

vjudge CountTables/2018雅礼集训 方阵 dp 斯特林反演的更多相关文章

  1. Loj #6503. 「雅礼集训 2018 Day4」Magic

    Loj #6503. 「雅礼集训 2018 Day4」Magic 题目描述 前进!前进!不择手段地前进!--托马斯 · 维德 魔法纪元元年. 1453 年 5 月 3 日 16 时,高维碎片接触地球. ...

  2. 「雅礼集训 2017 Day2」解题报告

    「雅礼集训 2017 Day2」水箱 我怎么知道这种题目都能构造树形结构. 根据高度构造一棵树,在树上倍增找到最大的小于约束条件高度的隔板,开一个 \(vector\) 记录一下,然后对于每个 \(v ...

  3. 雅礼集训1-9day爆零记

    雅礼集训1-9day爆零记 先膜一下虐爆我的JEFF巨佬 Day0 我也不知道我要去干嘛,就不想搞文化科 (文化太辣鸡了.jpg) 听李总说可以去看(羡慕)各路大佬谈笑风声,我就报一个名吧,没想到还真 ...

  4. LOJ_6045_「雅礼集训 2017 Day8」价 _最小割

    LOJ_6045_「雅礼集训 2017 Day8」价 _最小割 描述: 有$n$种减肥药,$n$种药材,每种减肥药有一些对应的药材和一个收益. 假设选择吃下$K$种减肥药,那么需要这$K$种减肥药包含 ...

  5. 雅礼集训【Day6-1】字符串

    雅礼集训[Day6-1]字符串 假设我们有串\(a\),我们设\(a'\)为\(a\)翻转后按为取反过后的串. 我们只考虑前一半的,长为\(m\)的串.如果前半截匹配了\(a\)或者\(a'\),则\ ...

  6. 「雅礼集训 2017 Day7」事情的相似度

    「雅礼集训 2017 Day7」事情的相似度 题目链接 我们先将字符串建后缀自动机.然后对于两个前缀\([1,i]\),\([1,j]\),他们的最长公共后缀长度就是他们在\(fail\)树上对应节点 ...

  7. 「雅礼集训 2017 Day1」 解题报告

    「雅礼集训 2017 Day1」市场 挺神仙的一题.涉及区间加.区间除.区间最小值和区间和.虽然标算就是暴力,但是复杂度是有保证的. 我们知道如果线段树上的一个结点,\(max=min\) 或者 \( ...

  8. [LOJ 6031]「雅礼集训 2017 Day1」字符串

    [LOJ 6031] 「雅礼集训 2017 Day1」字符串 题意 给定一个长度为 \(n\) 的字符串 \(s\), \(m\) 对 \((l_i,r_i)\), 回答 \(q\) 个询问. 每个询 ...

  9. [LOJ 6030]「雅礼集训 2017 Day1」矩阵

    [LOJ 6030] 「雅礼集训 2017 Day1」矩阵 题意 给定一个 \(n\times n\) 的 01 矩阵, 每次操作可以将一行转置后赋值给某一列, 问最少几次操作能让矩阵全为 1. 无解 ...

随机推荐

  1. Flask——实现上传功能

    1.实例 #!-*-coding=utf-8-*- # from flask import Flask # # app = Flask(__name__) # # # @app.route('/') ...

  2. Node js 入门指南(1)

    目录 Node Js 定义 特点 Node使用方式 Tip: 使用导出文件的注意事项 Node 内置模块 http 模块 定义 使用方法 fs 模块 定义 使用方法 读取文件方式 同步读取 异步读取 ...

  3. jira仪表盘的建立与共享

    一般在项目测试阶段,可以通过jira仪表盘清晰的展示bug的各个状态的数量,各个开发人员的bug数量. 有效督促开发解决问题. 也为测试日报提供了良好的数据支持,减少人工统计的工作量. 1.建议筛选器 ...

  4. day69 cookie与session

    目录 一.forms源码解析 二.cookie与session发展史 三.cookie操作 四.session操作 五.CBV如何添加装饰器 一.forms源码解析 # from组件的切入点是is_v ...

  5. Qt_Demo3:实现棋盘

    1  简介 参考视频:https://www.bilibili.com/video/BV1XW411x7NU?p=53 说明:实现一个8*8的棋盘,点击棋盘的任意位置显示一个表情,并打印出当前的坐标( ...

  6. java 面向对象(三十二):泛型一 泛型的理解

    1.泛型的概念所谓泛型,就是允许在定义类.接口时通过一个标识表示类中某个属性的类型或者是某个方法的返回值及参数类型.这个类型参数将在使用时(例如,继承或实现这个接口,用这个类型声明变量.创建对象时确定 ...

  7. python处理json总结

    一.首先,了解下什么是JSON? JSON:JavaScript Object Notation [JavaScript 对象表示法] JSON 是一种轻量级的数据交换格式,完全独立于任何程序语言的文 ...

  8. [Cordova-IOS]JavaScript与Swift交互

    [Cordova-IOS]Swift调用JavaScript中的函数 概述 Cordova中,通过插件的形式可以实现JavaScript与Swift的交互,关于Cordova插件的定义以及Swfit如 ...

  9. 01-flask电商项目开发基础配置

    本项目前端采用vue-cli的脚手架,后端采用Flask的Web框架.项目通过完成用户管理.权限管理.商品管理.订单管理.统计管理等功能,综合了前后端的知识,希望使大家都能受益. 1.使用到的技术如下 ...

  10. vscode切换虚拟环境报错无法加载文件 E:\Python_project\shop_env\Scripts\Activate.ps1,因为在此系统上禁止运行 脚本。

    在使用vscode切换python的虚拟环境时报错 解决方法如下: Windows+x打开面板,选择以管理员身份运行PowerShell,输入: set-executionpolicy remotes ...