好坑啊不开心……

  其实这题的想法还是比较简单粗暴的。题目明示恰好xxx,显然排除斜率二分这个玩意儿,那么不就只剩下容斥了嘛……

  令 \(A_{x}\) 为恰好出现了 \(S\) 次的至少有 \(x\) 种的方案数, \({B_{x}}\) 为恰好出现了\(S\) 次的颜色恰好 \(x\) 种的方案数。\(A_{x}\) 可以 \(O(1)\) 求得,\(A_{x} = \frac{\binom{n}{S * x} * (m - x) ^ {n - S * x} * (S * i)!}{(S!)^{x}}\)。(为了方便描述,我们在下面所说的颜色均为满足恰好出现 \(S\) 次的颜色)。

那么,一个恰好有 \(x\) 种颜色的方案对答案的贡献应该为

(我们先只考虑颜色种数恰好为 \(k\) 的)

\(g_{x} = [x = k] = \sum_{i = 0}^{x}\binom{x}{i}f_{i}\)

(\(f_{i}\) 为容斥系数)

二项式反演,得

\(f_{x} = \binom{k}{x} * (-1) ^ {k - x}\)

所以令 \(B_{x}\) 为恰好 \(x\) 种颜色的方案数,有:

\(B_{x} = \sum_{i = 0}^{m}\binom{m}{i}*A_{i}*\binom{i}{x}*(-1)^{i - x}\)

由于有 \(m\) 个\(B_{x}\) 要求值,且明显的给了一个NTT模数,

考虑转化成卷积的形式:

(把与各种变量相关的尽量整理到一起)

得到:\(B_{x} = \frac{(-1)^{-x}}{x!}\sum_{i = 0}^{m}\frac{\binom{m}{i}*(-1)^{i}}{(i - x)!}\)

前面的是个常数,后面的是一个卷积(把 \(i - x\) 先 \(+ m\) 再反转(防止爆负))……上NTT就好了。

  但这还没完!预处理逆元、阶乘逆元、阶乘的话会容易TLE!所以应该快速幂暴力处理逆元……(;′⌒`)

#include <bits/stdc++.h>
using namespace std;
#define maxn 10000005
#define mod 1004535809
#define int long long
int n, m, M, S, W[maxn], G[maxn], a[maxn], b[maxn], c[maxn];
int ans, K, fac[maxn], A[maxn], B[maxn];
int lim = , len, rev[maxn]; int read()
{
int x = , k = ;
char c; c = getchar();
while(c < '' || c > '') { if(c == '-') k = -; c = getchar(); }
while(c >= '' && c <= '') x = x * + c - '', c = getchar();
return x * k;
} int Up(int x) { if(x >= mod) x -= mod; return x; }
int Down(int x) { if(x < ) x += mod; return x; }
int Mod(int x) { x %= mod; if(x < ) x += mod; return x; }
int Qpow(int x, int timer)
{
int base = ;
for(; timer; timer >>= , x = x * x % mod)
if(timer & ) base = x * base % mod;
return base;
}
#define inv(x) Qpow(x, mod - 2) int C(int n, int m)
{
if(n < m || n < || m < ) return ;
int t = fac[n] * inv(fac[m]) % mod * inv(fac[n - m]) % mod;
return t;
} void init()
{
fac[] = ;
int t = max(n, m);
for(int i = ; i <= t; i ++) fac[i] = fac[i - ] * i % mod;
} void Pre()
{
for(int i = ; i <= m; i ++)
{
if(S * i > n) break;
int t = S * i, t1 = C(n, t) * fac[t] % mod;
A[i] = t1 * Qpow(inv(fac[S]), i) % mod * Qpow(m - i, n - t) % mod;
}
for(int i = ; i <= m; i ++)
a[i] = C(m, i) * A[i] % mod * fac[i] % mod * Qpow(-, i) % mod;
for(int i = -m; i <= m; i ++) c[i + K] = i < ? : inv(fac[i]);
for(int i = ; i <= M; i ++) b[i] = c[M - i];
} void NTT(int *A, int opt)
{
int t = opt < ? Qpow(, mod - ) : ;
for(int i = ; i < lim; i ++)
if(i < rev[i]) swap(A[i], A[rev[i]]); for(int l = ; l < lim; l <<= )
{
int g = Qpow(t, (mod - ) / (l << ));
for(int i = ; i < l; i ++) G[i] = 1ll * G[i - ] * g % mod;
for(int i = ; i < lim; i += (l << ))
for(int j = i; j <= i + l - ; j ++)
{
int x = A[j], y = 1ll * G[j - i] * A[j + l] % mod;
A[j] = Up(x + y); A[j + l] = Down(x - y);
}
}
} signed main()
{
n = read(), m = read(), S = read(); K = m, M = m * + ;
for(int i = ; i <= m; i ++) W[i] = read();
init(), Pre(); G[] = ;
while(lim <= M + m) lim <<= , len ++;
for(int i = ; i < lim; i ++)
rev[i] = (rev[i >> ] >> ) | ((i & ) << ((len - )));
NTT(a, ), NTT(b, );
for(int i = ; i < lim; i ++) a[i] = a[i] * b[i] % mod;
NTT(a, -); int inv1 = Qpow(lim, mod - );
for(int i = ; i <= m; i ++)
{
int t = ((i & ) ? - : ) * inv(fac[i]) % mod * W[i] % mod;
ans = Mod(ans + a[i + m + ] * inv1 % mod * t % mod);
}
printf("%lld\n", ans);
return ;
}

【题解】HAOI2018染色的更多相关文章

  1. 【题解】[HAOI2018]染色(NTT+容斥/二项式反演)

    [题解][HAOI2018]染色(NTT+容斥/二项式反演) 可以直接写出式子: \[ f(x)={m \choose x}n!{(\dfrac 1 {(Sx)!})}^x(m-x)^{n-Sx}\d ...

  2. [洛谷P4491] [HAOI2018]染色

    洛谷题目链接:[HAOI2018]染色 题目背景 HAOI2018 Round2 第二题 题目描述 为了报答小 C 的苹果, 小 G 打算送给热爱美术的小 C 一块画布, 这块画布可 以抽象为一个长度 ...

  3. 【LG4491】[HAOI2018]染色

    [LG4491][HAOI2018]染色 题面 洛谷 题解 颜色的数量不超过\(lim=min(m,\frac nS)\) 考虑容斥,计算恰好出现\(S\)次的颜色至少\(i\)种的方案数\(f[i] ...

  4. 题解-HAOI2018全套

    去冬令营转了一圈发现自己比别人差根源在于刷题少,见过的套路少(>ω<) 于是闲来无事把历年省选题做了一些 链接放的都是洛谷的,bz偷懒放的也是链接 AM.T1 奇怪的背包 Problem ...

  5. BZOJ 5306 [HAOI2018] 染色

    BZOJ 5306 [HAOI2018] 染色 首先,求出$N$个位置,出现次数恰好为$S$的颜色至少有$K$种. 方案数显然为$a_i=\frac{n!\times (m-i)^{m-i\times ...

  6. 【BZOJ5306】 [Haoi2018]染色

    BZOJ5306 [Haoi2018]染色 Solution xzz的博客 代码实现 #include<stdio.h> #include<stdlib.h> #include ...

  7. [BZOJ5306] [HAOI2018]染色(容斥原理+NTT)

    [BZOJ5306] [HAOI2018]染色(容斥原理+NTT) 题面 一个长度为 n的序列, 每个位置都可以被染成 m种颜色中的某一种. 如果n个位置中恰好出现了 S次的颜色有 K种, 则小 C ...

  8. [题解 LuoguP4491 [HAOI2018]染色

    传送门 神仙计数题 Orz 先令\(F[k]\)表示出现次数恰好为\(S\)次的颜色恰好有\(k\)中的方案数,那么 \[Ans=\sum\limits_{i=0}^mW_iF[i]\] 怎么求\(F ...

  9. 【BZOJ5306】[HAOI2018]染色(NTT)

    [BZOJ5306]染色(NTT) 题面 BZOJ 洛谷 题解 我们只需要考虑每一个\(W[i]\)的贡献就好了 令\(lim=min(M,\frac{N}{S})\) 那么,开始考虑每一个\(W[i ...

随机推荐

  1. Mysql优化之索引

    前言 这几天抽了个时间将<高性能Mysql>看了一下忽觉索引非常之重要,习之然后总结巩固知识.本文索引使用的是InnoDB存储引擎.因为本文并不是说用索引的好处,所以并不会书写QPS之类的 ...

  2. Caffe Blob针对图像数据在内存中的组织方式

    Caffe使用Blob结构在CNN网络中存储.传递数据.对于批量2D图像数据,Blob的维度为 图像数量N × 通道数C × 图像高度H × 图像宽度W 显然,在此种场景下,Blob使用4维坐标定位数 ...

  3. 3. 第一个程序Hello, World!

    第一个接口 HelloWorld 本项目所有代码均可在github上下载. 1. 编辑config.py # 基础配置类 import os class Config(object): ROOT = ...

  4. Netty源码分析第8章(高性能工具类FastThreadLocal和Recycler)---->第1节: FastThreadLocal的使用和创建

    Netty源码分析第八章: 高性能工具类FastThreadLocal和Recycler 概述: FastThreadLocal我们在剖析堆外内存分配的时候简单介绍过, 它类似于JDK的ThreadL ...

  5. [文章存档]Kudu 的 Debug Console 窗口如何查看更多文件

    链接:https://docs.azure.cn/zh-cn/articles/azure-operations-guide/app-service-web/aog-app-service-web-h ...

  6. 基于WebSocket协议的性能测试

    互联网应用时代,用户获取信息的方式从传统媒体到新媒体,信息时效性对通信技术要求越来越高, HTTP协议已经不能适用.于是WebSocket出现了,它实现浏览器与服务器的全双工通信,服务端主动向客户端发 ...

  7. java中重要的多线程工具类

    前言 之前学多线程的时候没有学习线程的同步工具类(辅助类).ps:当时觉得暂时用不上,认为是挺高深的知识点就没去管了.. 在前几天,朋友发了一篇比较好的Semaphore文章过来,然后在浏览博客的时候 ...

  8. Python之并发编程-多进程

    目录 一.multiprocessiong模块介绍 二.Process类的介绍 三.进一步介绍(守护进程.锁.队列.管道.事件等) 1.守护进程 2.锁(同步锁.互斥锁) 3.信号量(了解) 4.队列 ...

  9. React Native (0.57)开发环境搭建(注意:Node不要随便更新到最新版,更新完后莫名其妙的问题一大堆)

    搭建开发环境 一.安装依赖 必须安装的依赖有:Node.Watchman 和 React Native 命令行工具以及 Xcode. 1.首先安装 Homebrew 2.安装 Node, Watchm ...

  10. HDU 4539 郑厂长系列故事——排兵布阵 状压dp

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4539 郑厂长系列故事--排兵布阵 Time Limit: 10000/5000 MS (Java/O ...