传送门

一道非常好的容斥+NTT,对我这样的菜鸡难度稍高。
符合要求的颜色最多有\(lim = min(m,\lfloor\frac{n}{S}\rfloor)\)种。
首先,考虑恰好出现S次不是很容易,那么我们换一种想法,先考虑至少出现S次。设\(f[i]\)表示至少有i种颜色出现S次的情况数。
首先要从m种颜色选i种,这是\(C_m^i\)种情况。
之后我们考虑取出的位置,i种颜色占用的位置是iS个,这是\(C_n^{iS}\)种情况。
再考虑取出iS个位置中颜色的 摆放情况。因为颜色是相同的,所以应该是无标号的全排列,也就是\(\frac{(iS!)}{(S!)^i}\)种情况。
最后剩下的位置可以随便乱染,就是\((m-i)^{n-iS}\)种情况。

用乘法原理乘起来,有\(f[i] = C_m^iC_n^{iS}\frac{(iS!)}{(S!)^i}(m-i)^{n-iS}\)

之后我们考虑\(ans[i]\)表示恰好有i种颜色出现S次的情况。
那么根据容斥原理可以想得到,\(ans[i] = \sum_{j=i}^{lim}(-1)^{j-i}C_j^if[j]\)
把组合数拆开,把\(i!\)移到等式左边,\(ans[i]*i! = \sum_{j=i}^{lim}\frac{(-1)^{j-i}}{(j-i)!}j!f[j]\)
我们设\(F(x) = \frac{-1^i}{i!}x^i,G(x) = f[i]i!x^i\)
然后这个就已经非常像一个卷积的形式了……我们考虑把G反转就可以卷积……
之后再把卷积出来得到的答案数组反转过来对应的就是答案了。
最后对应的乘起来累加即为答案。
注意这道题预处理阶乘逆元的时候,要处理到\(max(n,m)\),否则可能会导致访问到没有处理的位置。
出题人比较良心的给了NTT模数,原根是3.

#include<bits/stdc++.h>
#define rep(i,a,n) for(int i = a;i <= n;i++)
#define per(i,n,a) for(int i = n;i >= a;i--)
#define enter putchar('\n')
#define fr friend inline
#define y1 poj
#define mp make_pair
#define pr pair<int,int>
#define fi first
#define sc second
#define pb push_backusing namespace std;
typedef long long ll;
const int M = 2e5+5;
const int N = 2e7+5;
const int mod = 1004535809;
const int G = 3;
const int invG = 334845270;
const double eps = 1e-7;int read()
{int ans = 0,op = 1;char ch = getchar();while(ch < '0' || ch > '9') {if(ch == '-') op = -1;ch = getchar();}while(ch >= '0' && ch <= '9') ans = ans * 10 + ch - '0',ch = getchar();return ans * op;
}int n,m,s,w[M],fac[N],inv[N],rev[M<<2],F[M<<2],g[M<<2],ans[M<<2],f[M<<2],lim,tot;int inc(int a,int b){return (a+b) % mod;}
int mul(int a,int b){return 1ll * a * b % mod;}
int qpow(int a,int b)
{int p = 1;while(b){if(b & 1) p = mul(p,a);a = mul(a,a),b >>= 1;}return p;
}void NTT(int *a,int l,int f)
{rep(i,0,l-1) if(i < rev[i]) swap(a[i],a[rev[i]]);for(int i = 1;i < l;i <<= 1){int w1 = qpow(f ? G : invG,(mod-1) / (i<<1));for(int j = 0;j < l;j += (i<<1)){int w = 1;rep(k,0,i-1){int kx = a[k+j],ky = mul(a[k+j+i],w);a[k+j] = inc(kx,ky),a[k+j+i] = inc(kx,mod-ky),w = mul(w,w1);}}}if(!f){int inv = qpow(l,mod-2);rep(i,0,l-1) a[i] = mul(a[i],inv);}
}void init()
{int k = max(n,m);fac[0] = inv[0] = inv[1] = 1;rep(i,1,k) fac[i] = mul(fac[i-1],i);inv[k] = qpow(fac[k],mod-2);per(i,k-1,1) inv[i] = mul(inv[i+1],i+1);
}int C(int n,int m)
{if(n < m) return 0;return mul(mul(fac[n],inv[m]),inv[n-m]);
}int main()
{n = read(),m = read(),s = read(),init(),lim = min(m,n/s);rep(i,0,m) w[i] = read();rep(i,0,lim) f[i] = mul(mul(mul(C(m,i),C(n,i*s)),mul(fac[i*s],qpow(inv[s],i))),qpow(m-i,n-i*s));g[0] = 1,F[0] = f[0];rep(i,1,lim){F[i] = mul(f[i],fac[i]);(i & 1) ? g[i] = mod - inv[i] : g[i] = inv[i];}int l = 1,L = 0;while(l <= lim<<1) l <<= 1,L++;rep(i,0,l-1) rev[i] = (rev[i>>1] >> 1) | ((i&1) << (L-1));reverse(F,F+lim+1);NTT(F,l,1),NTT(g,l,1);rep(i,0,l-1) F[i] = mul(F[i],g[i]);NTT(F,l,0);reverse(F,F+lim+1);rep(i,0,lim) tot = inc(tot,mul(mul(F[i],inv[i]),w[i]));printf("%d\n",tot);return 0;
}

转载于:https://www.cnblogs.com/captain1/p/10459103.html

HAOI2018 染色相关推荐

  1. P4491 [HAOI2018]染色

    反思 二项式反演的板子,但是还要加上一个NTT,就变得恶心人了 我NTT写挂调了好长时间... 注意 NTT应该这么写 int tmp=pow((opt)?invG:G,(MOD-1)/i); 而不这 ...

  2. [HAOI2018]染色

    题解 我竟然能自己想出来计数题 容斥+NTT 首先一看到题目让求恰好出现\(S\)次的颜色有恰好\(K\)种就想到容斥 如果容斥每种颜色出现次数的话并不好计数 那么考虑容斥恰好出现\(S\)次的颜色有 ...

  3. [HAOI2018] 染色(二项式反演+NTT)

    洛谷链接 显然颜色数量不会超过 lim⁡=min⁡(m,ns)\lim=\min(m,\frac ns)lim=min(m,sn​) fi:f_i:fi​: 至少有 iii 种颜色恰好出现了 sss ...

  4. Luogu 4491 [HAOI2018]染色

    BZOJ 5306 考虑计算恰好出现$s$次的颜色有$k$种的方案数. 首先可以设$lim = min(m, \left \lfloor \frac{n}{s} \right \rfloor)$,我们 ...

  5. PKUWC2019游记

    PKUWC2019游记 \(Day\) 很久之前 听说 \(440\) 能去 \(PKUWC\),惊喜啊!其实就是为期末考爆炸找个借口 最近感觉学了不少东西.虽然 \(PKUWC\) 的题目以组合和数 ...

  6. 「HAOI2018」染色 解题报告

    「HAOI2018」染色 是个套路题.. 考虑容斥 则恰好为\(k\)个颜色恰好为\(c\)次的贡献为 \[ \binom{m}{k}\sum_{i\ge k}(-1)^{i-k}\binom{m-k ...

  7. 【HAOI2018】染色【反向二项式反演】【NTT卷积】

    传送门 题意:NNN个位置染MMM种颜色,恰好出现SSS次的颜色数量恰好为kkk时的愉悦度为wkw_kwk​,求所有方案的愉悦度之和.对100453580910045358091004535809取模 ...

  8. [C] 深度优先搜索解决连通块/染色问题——求岛的个数

    本文介绍用DFS解决连通块个数问题 有关dfs的介绍见另外一篇:不撞南墙不回头--深度优先搜索 例题 宝岛探险 题目描述 一个小岛由一个主岛和一些复附属岛屿组成,该岛使用一个二维矩阵表示,其中数字表示 ...

  9. [BZOJ4033][HAOI2015]树上染色

    4033: [HAOI2015]树上染色 Time Limit: 10 Sec  Memory Limit: 256 MB Submit: 2108  Solved: 901 [Submit][Sta ...

最新文章

  1. view(*args)改变张量的大小和形状_pytorch reshape numpy
  2. 通俗易懂了解Vue双向绑定原理及实现
  3. tomcat启动报:No Spring WebApplicationInitializer types detected on classpath
  4. 图像正确(相当于这个小项目就要结尾了)
  5. github博客突然无法访问_紫菜头博客被DNS污染攻击关站
  6. 查找算法系列之复杂算法:哈希查找
  7. linux tar压缩权限,LINUX 文件/组/帮助/权限/文件压缩/管道
  8. Effective_STL 学习笔记(十七) 使用 “交换技巧” 来修整过剩的容量
  9. Android编码规范
  10. 使用spack mirror简化离线环境的包安装
  11. 联想机房升级Win10联想硬盘保护系统EDU8.0安装手记
  12. 速卖通热卖产品推荐—2021年速卖通家居行业厨房用品热卖产品趋势
  13. 【WAF技巧拓展】————4、web应用防火墙逃逸技术(一)
  14. 华为云教程(云数据库RDS)
  15. V831——识别指定的人脸
  16. 建设银行上海住房公积金业务网点
  17. 《打地鼠》游戏简单制作
  18. DeepFashion2: 一个针对衣服图片的检测、姿态估计、分割和重认证多用途基准
  19. 使用kail中Metasploit获取Windows的权限并提权
  20. 再谈搜索已死,推荐上位

热门文章

  1. pku 1925 Spiderman DP
  2. MDK4 如何生成bin文件
  3. Java格式化Date为字符串的高级写法
  4. MySQL · 引擎特性 · InnoDB 事务子系统介绍
  5. [QTP] 描述性编程
  6. Error establishing a database connection!
  7. ASP.NET文件下载
  8. Android Context应用上下文详解
  9. 第五章spring框架基础
  10. Eclipse android