ARG102E:Stop. Otherwise...
Sol
对于每个 \(i\) ,可以把 \(k\) 个数字分成 \((x,i-x)\) 的若干组。
那么就是求每组只能其中选择一个且可以重复的方案数。
预处理 \(f[i][j]\) 表示从 \(j\) 个组内选 \(i\) 个,每个组必须选的方案数。
\(f[i][j]=(f[i-1][j]+f[i-1][j-1]\times 2)\) 注意组有序,而选出来是无序的,所以要强制选择最后一组
那么每个组可以不选的方案数 \(g[i][j]\) 就是
\]
拆开组合数可以 \(NTT\) 优化。
对于询问分两种情况
- \(i\) 为奇数
那么 \(x\ne i-x\) 直接枚举多少个选组内的,其它的可重组合即可 - \(i\) 为偶数
存在一组 \(x=i-x\) 枚举是否选 \(x\) (因为只能选一个),然后像奇数一样做即可
\(\Theta(n^2logn)\) 丝毫不虚
# include <bits/stdc++.h>
using namespace std;
typedef long long ll;
namespace IO {
const int maxn((1 << 21) + 1);
char ibuf[maxn], *iS, *iT, c;
int f;
inline char Getc() {
return iS == iT ? (iT = (iS = ibuf) + fread(ibuf, 1, maxn, stdin), iS == iT ? EOF : *iS++) : *iS++;
}
template <class Int> inline void In(Int &x) {
for (f = 1, c = Getc(); c < '0' || c > '9'; c = Getc()) f = c == '-' ? -1 : 1;
for (x = 0; c >= '0' && c <= '9'; c = Getc()) x = (x << 1) + (x << 3) + (c ^ 48);
x *= f;
}
}
using IO :: In;
const int maxn(4005);
const int mod(998244353);
int f[maxn][maxn], c[maxn][maxn], fac[maxn], ifac[maxn];
inline void Inc(int &x, int y) {
x += y;
if (x >= mod) x -= mod;
}
inline int Pow(ll x, int y) {
ll ret = 1;
for (; y; y >>= 1, x = x * x % mod)
if (y & 1) ret = ret * x % mod;
return ret;
}
inline int Calc(int n, int num, int res) {
int ret = 0;
if (!res) ret = f[n][num];
else {
for (int j = 0; j <= n; ++j)
Inc(ret, 1LL * f[n - j][num] * c[j + res - 1][j] % mod);
}
return ret;
}
int a[maxn << 2], b[maxn << 2], len, l, r[maxn << 2], w[2][maxn << 2];
inline void NTT(int *p, int opt) {
for (int i = 0; i < len; ++i) if (i < r[i]) swap(p[i], p[r[i]]);
for (int i = 1; i < len; i <<= 1)
for (int j = 0, t = i << 1; j < len; j += t)
for (int k = 0; k < i; ++k) {
int nw = w[opt == -1 ? 1 : 0][len / i * k];
int x = p[j + k], y = 1LL * p[j + k + i] * nw % mod;
p[j + k] = (x + y) % mod, p[j + k + i] = (x - y + mod) % mod;
}
if (opt == -1) {
int inv = Pow(len, mod - 2);
for (int i = 0; i < len; ++i) p[i] = 1LL * p[i] * inv % mod;
}
}
inline void Init() {
f[0][0] = c[0][0] = ifac[0] = fac[0] = 1;
for (int i = 1, j; i <= 4000; ++i)
for (c[i][0] = j = 1; j <= i; ++j)
c[i][j] = (c[i - 1][j] + c[i - 1][j - 1]) % mod;
for (int i = 1; i <= 2000; ++i)
for (int j = 1; j <= 2000; ++j)
f[i][j] = (f[i - 1][j] + 1LL * f[i - 1][j - 1] * 2 % mod) % mod;
for (int i = 1; i <= 2000; ++i) fac[i] = 1LL * fac[i - 1] * i % mod;
ifac[2000] = Pow(fac[2000], mod - 2);
for (int i = 1999; i; --i) ifac[i] = 1LL * ifac[i + 1] * (i + 1) % mod;
for (len = 1; len <= 4000; len <<= 1) ++l;
for (int i = 0; i < len; ++i) r[i] = (r[i >> 1] >> 1) | ((i & 1) << (l - 1));
for (int i = 1; i < len; i <<= 1) {
int wn = Pow(3, (mod - 1) / (i << 1));
for (int nw = 1, k = 0; k < i; ++k, nw = 1LL * nw * wn % mod)
w[0][len / i * k] = nw, w[1][len / i * k] = Pow(nw, mod - 2);
}
for (int i = 0; i <= 2000; ++i) {
for (int j = 0; j < len; ++j) a[j] = b[j] = 0;
for (int j = 0; j <= 2000; ++j) a[j] = ifac[j], b[j] = 1LL * ifac[j] * f[i][j] % mod;
NTT(a, 1), NTT(b, 1);
for (int j = 0; j < len; ++j) a[j] = 1LL * a[j] * b[j] % mod;
NTT(a, -1);
for (int j = 0; j <= 2000; ++j) f[i][j] = 1LL * a[j] * fac[j] % mod;
}
}
int n, k;
int main() {
In(k), In(n), Init();
int r = k << 1;
for (int i = 2; i <= r; ++i) {
if (i & 1) {
int num = max(0, min(i >> 1, i - 1) - max(1, i - k) + 1);
int res = k - (num << 1);
printf("%d\n", Calc(n, num, res));
}
else {
int num = max(0, min(i >> 1, i - 1) - max(1, i - k) + 1);
int res = k - (num << 1) + 1;
if (num) --num;
printf("%d\n", (Calc(n, num, res) + Calc(n - 1, num, res)) % mod);
}
}
return 0;
}
ARG102E:Stop. Otherwise...的更多相关文章
- java web 开发三剑客 -------电子书
Internet,人们通常称为因特网,是当今世界上覆盖面最大和应用最广泛的网络.根据英语构词法,Internet是Inter + net,Inter-作为前缀在英语中表示“在一起,交互”,由此可知In ...
- 所有selenium相关的库
通过爬虫 获取 官方文档库 如果想获取 相应的库 修改对应配置即可 代码如下 from urllib.parse import urljoin import requests from lxml im ...
- In-Memory:内存数据库
在逝去的2016后半年,由于项目需要支持数据的快速更新和多用户的高并发负载,我试水SQL Server 2016的In-Memory OLTP,创建内存数据库实现项目的负载需求,现在项目接近尾声,系统 ...
- 从直播编程到直播教育:LiveEdu.tv开启多元化的在线学习直播时代
2015年9月,一个叫Livecoding.tv的网站在互联网上引起了编程界的注意.缘于Pingwest品玩的一位编辑在上网时无意中发现了这个网站,并写了一篇文章<一个比直播睡觉更奇怪的网站:直 ...
- 【.net 深呼吸】细说CodeDom(8):分支与循环
有人会问,为啥 CodeDom 不会生成 switch 语句,为啥没生成 while 语句之类.要注意,CodeDom只关心代码逻辑,而不是语法,语法是给写代码的人用的.如果用.net的“反编译”工具 ...
- 【原】Android热更新开源项目Tinker源码解析系列之三:so热更新
本系列将从以下三个方面对Tinker进行源码解析: Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Android热更新开源项目Tinker源码解析系列之二:资源文件热更新 A ...
- App开发:模拟服务器数据接口 - MockApi
为了方便app开发过程中,不受服务器接口的限制,便于客户端功能的快速测试,可以在客户端实现一个模拟服务器数据接口的MockApi模块.本篇文章就尝试为使用gradle的android项目设计实现Moc ...
- TODO:macOS编译PHP7.1
TODO:macOS编译PHP7.1 本文主要介绍在macOS上编译PHP7.1,有兴趣的朋友可以去尝试一下. 1.下载PHP7.1源码,建议到PHP官网下载纯净到源码包php-7.1.0.tar.g ...
- In-Memory:在内存中创建临时表和表变量
在Disk-Base数据库中,由于临时表和表变量的数据存储在tempdb中,如果系统频繁地创建和更新临时表和表变量,大量的IO操作集中在tempdb中,tempdb很可能成为系统性能的瓶颈.在SQL ...
随机推荐
- day 11 前方高能-迭代器
第一类对象 -----函数名 == 变量名 函数对象可以像变量一样进行赋值 还可以作为列表的元素进行使用 可以作为返回值返回 def wrapper(): def inner(): ...
- # 2017-2018-2 20155319『网络对抗技术』Exp4:恶意代码分析
2017-2018-2 20155319『网络对抗技术』Exp4:恶意代码分析 实验目标与基础问题 ++1.实践目标++ 监控你自己系统的运行状态,看有没有可疑的程序在运行. 分析一个恶意软件,就分析 ...
- # 20155337《网络对抗》Web基础
20155337<网络对抗>Exp8 Web基础 实践目标 1. 实践内容 (1).Web前端HTML 能正常安装.启停Apache.理解HTML,理解表单,理解GET与POST方法,编写 ...
- 【php增删改查实例】第一节 - PHP开发环境配置
最近需要使用PHP,于是把平时的积累整理一下,就有了这个教程. 首先是环境配置: 1.操作系统:windos7 2.后台:PHP 3.前台:Html + js + css 4.数据库:MYSQL 5. ...
- Python中类和对象在内存中是如何保存?
类以及类中的方法在内存中只有一份,而根据类创建的每一个对象都在内存中需要存一份,大致如下图: 如上图所示,根据类创建对象时,对象中除了封装 name 和 age 的值之外,还会保存一个类对象指针,该值 ...
- JavaScript闭包简单应用
闭包定义 在JavaScript中,当一个内部函数被其外部函数之外的变量引用时,就形成了一个闭包.简单说,闭包就是能够读取其他函数内部变量的函数. 闭包的作用: 1. 可以读取函数内部的变量 2. 让 ...
- TensorFlow 训练MNIST数据集(2)—— 多层神经网络
在我的上一篇随笔中,采用了单层神经网络来对MNIST进行训练,在测试集中只有约90%的正确率.这次换一种神经网络(多层神经网络)来进行训练和测试. 1.获取MNIST数据 MNIST数据集只要一行代码 ...
- Asp.Net_抓包解析xml文件为json
protected void Button1_Click(object sender, EventArgs e) { string Phone = this.Txt_Con.Text; string ...
- if 判断文件
#!/bin/sh#判断文件存在,判断是否为文件夹等testPath="/Volumes/MacBookProHD/Mr.Wen/08 shell命令"testFile=" ...
- 每个国家对应的语言Locale和国家代码对照表(转)
转载 jacksoft DNN3支持多语言,希望下面的语言代码与对应国家能对你有所帮助 语言代码 国家/ 地区 "" (空字符串) 无变化的文化 af 公用荷兰语 af-ZA 公用 ...