复函数,递归代入,可以得到最终的式子为$f(x-\sum_{i=1}^{m}{a_i})$,且$f(x) = \sum_{i = 0}^{n}{c_ix^i}$,求最终各个x项的系数。

设$S=\sum_{i=1}^{m}{a_i}$

先二项式展开

\begin{eqnarray*} f(x-S)&=&\sum_{i=0}^{n}{c_i{(x-S)}^i} \newline &=&\sum_{i=0}^{n}{ c^i\sum_{j=0}^{i}{ \binom{j}{i}x^{j}(-S)^{i-j} } }\end{eqnarray*}

交换求和符号

\begin{eqnarray*}&=&\sum_{j=0}^{n}{ x^{j} \sum_{i=0}^{n-j}{c_{i+j}\binom{j}{i+j}(-S)^{i}} } \newline &=&\sum_{j=0}^{n}{ x^{j} \sum_{i=0}^{n-j}{c_{i+j}\frac{(i+j)!}{{i!}{j!}}(-S)^{i}} }\newline &=&\sum_{j=0}^{n}{ \frac{x^{j}}{j!} \sum_{i=0}^{n-j}{c_{i+j}(i+j)! \frac{(-S)^{i}}{i!} } }\end{eqnarray*}

因为只要系数,也就是说对于每个j,得到对应的${j!}b_j$,求后一个求和符号里的值就行了

注意到卷积公式$\sum^{n}_{i=0}{f(i)h(n-i)}= f(n)*h(n)$,而且模数998244353是费马素数

故设$k = n - j, A[i] = \frac{(-S)^{i}}{i!},B[i]=c_{k-i-i}(k-i-j)! $,则$C[n - j] =\sum_{i=0}^{j}A[i]B[n-j-i]=\sum_{i=0}^{n-j} c_{i+j}(i+j)! \frac{(-S)^{i}}{i!} $

对A和B使用NTT加速卷积的计算,最后结果在A[i]上,记得反转为A[n-i]。推公式化卷积式,套模板。

#include <bits/stdc++.h>
#define LL long long
using namespace std; const LL N = 1e5 + 10;
const LL mod = 998244353;
const int g = 3;
const int maxlen = 1 << 18; LL wn[maxlen], fac[N], inv[N]; LL fpow(LL a, LL n)
{
LL ans = 1;
while(n)
{
if(n & 1)
ans = (ans * a % mod + mod) %mod;
a = (a * a + mod) % mod;
n >>= 1;
}
return ans;
} void init()
{
wn[0] = 1;
wn[1] = fpow(g, ((mod - 1)>>18));
for(int i = 2; i < maxlen; i++)
wn[i] = wn[i - 1] * wn[1] % mod;
fac[1] = inv[1] = 1;
fac[0] = inv[0] = 1;
for(int i = 2; i < N; i++)
{
fac[i] = fac[i - 1] * i % mod;
inv[i] = (mod - mod / i) * inv[mod % i] % mod;
}
for(int i = 1; i < N; i++)
(inv[i] *= inv[i - 1]) %= mod;
} void rader(LL f[], int len)
{
for(int i = 1, j = len >> 1; i < len - 1; i++)
{
if(i < j) swap(f[i], f[j]);
int k = len >> 1;
while(j >= k)
{
j -= k;
k >>= 1;
}
if(j < k) j += k;
}
}
void ntt(LL f[], int len, int on)
{
/*for(int i = 0, j = 0; i < len;i++)
{
if(i > j) swap(f[i], f[j]);
for(int l = len >> 1; (j^=l) < l; l>>=1);
}*/
rader(f, len);
for(int i = 1, d = 1; d < len; i++, d <<= 1)
{
//LL wnn = fpow(g, (mod-1)/(d<<1));
for(int j = 0; j < len; j += (d << 1))
{
//LL w = 1;
for(int k = 0; k < d; k++)
{
LL t = wn[(maxlen >> i) * k] * f[j + k + d] % mod;
//LL t = w*f[j+k+d]%mod;
//w = w*wnn % mod;
f[j + k + d] = ((f[j + k] - t) % mod + mod) % mod;
f[j + k] = ((f[j + k] + t) % mod + mod) % mod;
}
}
}
if(on == -1)
{
reverse(f + 1, f + len);
LL inv2 = fpow(len, mod - 2);
for(int i = 0; i < len; i++)
f[i] = f[i] % mod * inv2 % mod;
}
} void work(LL a[], LL b[], int len)
{
ntt(a, len, 1);
ntt(b, len, 1);
for(int i = 0; i < len; i++)
a[i] = (a[i] * b[i] % mod + mod) % mod;
ntt(a, len, -1);
} LL A[maxlen], B[maxlen], Suma, c[N];
int n, m;
int main()
{
init();
while(~scanf("%d", &n))
{
for(int i = 0; i <= n; i++) scanf("%lld", c + i);
scanf("%d", &m);
Suma = 0;
LL t;
for(int i = 0; i < m; i++)
scanf("%lld", &t), Suma -= t;
Suma = (Suma + mod) % mod;
while(Suma < 0)
Suma += mod;
if(Suma == 0)
{
for(int i = 0; i <= n; i++)
printf("%lld ", c[i]);
printf("\n");
continue;
}
//getLength
int len = 1;
while(len <= 2*n) len <<= 1;
//
LL ae = 1;
for(int i = 0; i < len; i++)
{
if(i <= n)
{
B[i] = ae * inv[i] % mod;
A[i] =(fac[n - i] * c[n - i]) % mod;
}
else A[i] = B[i] = 0;
ae = (ae * Suma) % mod;
//cout << A[i] << "~"<< B[i] << endl;
}
work(A, B, len);
for(int i = 0; i <= n; i++)
A[i] = A[i] * inv[n - i] % mod;
for(int i = 0; i <= n; i++)
printf("%lld ", A[n - i]);
printf("\n");
}
}

HDU 6061 推导 NTT的更多相关文章

  1. 2017 多校3 hdu 6061 RXD and functions

    2017 多校3 hdu 6061 RXD and functions(FFT) 题意: 给一个函数\(f(x)=\sum_{i=0}^{n}c_i \cdot x^{i}\) 求\(g(x) = f ...

  2. HDU 6061 - RXD and functions | 2017 Multi-University Training Contest 3

    每次NTT都忘记初始化,真的是写一个小时,Debug两个小时- - /* HDU 6061 - RXD and functions [ NTT ] | 2017 Multi-University Tr ...

  3. HDU 6061 RXD and functions(NTT)

    题意 给定一个\(n​\) 次的 \(f​\) 函数,向右移动 \(m​\) 次得到 \(g​\) 函数,第 \(i​\) 次移动长度是 \(a_i​\) ,求 \(g​\) 函数解析式的各项系数,对 ...

  4. HDU 6061 RXD and functions NTT

    RXD and functions Problem Description RXD has a polynomial function f(x), f(x)=∑ni=0cixiRXD has a tr ...

  5. HDU 6061 RXD and functions

    题目链接:HDU-6061 题意:给定f(x),求f(x-A)各项系数. 思路:推导公式有如下结论: 然后用NTT解决即可. 代码: #include <set> #include < ...

  6. HDU 5322 Hope ——NTT 分治 递推

    发现可以推出递推式.(并不会) 然后化简一下,稍有常识的人都能看出这是一个NTT+分治的情况. 然而还有更巧妙的方法,直接化简一下递推就可以了. 太过巧妙,此处不表,建议大家找到那篇博客. 自行抄写 ...

  7. HDU 5279 分治NTT 图的计数

    思路: 显然每个子图内都是森林 去掉所有子图1和n都连通且每条大边都存在的情况 直接DP上 NTT优化一波 注意前两项的值.. //By SiriusRen #include <bits/std ...

  8. HDU 5734 Acperience (推导)

    Acperience 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5734 Description Deep neural networks (DN ...

  9. HDU 2086 A1 = ? (找规律推导公式 + 水题)(Java版)

    Equations 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2086 ——每天在线,欢迎留言谈论. 题目大意: 有如下方程:Ai = (Ai-1 ...

随机推荐

  1. MySql 8 命令

    1-创建用户 create user 用户名@'%' identified by '密码'; create user 用户名@'localhost' identified by '密码';   2-授 ...

  2. IT小小鸟 读书笔记

    讲真的,整本书我并没有看完,翻阅了一下,然后小小的借鉴了一下! 首先设计你自己的进度条 进度条的设计是一个很多人都知道的故事:同样的耗时,如果不给任何进度提示,只是在完成之后才弹出一个完成消息,中间没 ...

  3. Alpha 冲刺5

    队名:日不落战队 安琪(队长) 今天完成的任务 组织第五次站立式会议(半冲刺总结交流会). 完成草稿箱前端界面. 明天的计划 回收站前端界面. 尝试去调用数据. 还剩下的任务 信息修改前端界面. 遇到 ...

  4. Ubuntu中Google Chrome安装

    转载自博客 1. 方法一   1.在ubuntu中启动终端   2.在终端中,输入以下命令: sudo wget http://www.linuxidc.com/files/repo/google-c ...

  5. lintcode-65-两个排序数组的中位数

    65-两个排序数组的中位数 两个排序的数组A和B分别含有m和n个数,找到两个排序数组的中位数,要求时间复杂度应为O(log (m+n)). 样例 给出数组A = [1,2,3,4,5,6] B = [ ...

  6. QSerialPort-Qt串口通讯

    版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:QSerialPort-Qt串口通讯     本文地址:http://techieliang. ...

  7. 在DBGrid中实现多选功能

    1.首先把DBGrid->options-dgMulitSelect设为True.  dgRowSelect也设为True,此属性设为true后,DBGrid将不能编辑,如何实现能否编辑代码如下 ...

  8. 第184天:js创建对象的几种方式总结

    面向对象编程(OOP)的特点: 抽象:抓住核心问题 封装:只能通过对象来访问方法 继承:从已有的对象下继承出新的对象 多态:多对象的不同形态 一.创建对象的几种方式 javascript 创建对象简单 ...

  9. 第111天:Ajax之jQuery实现方法

    由于jQuery中的Ajax方法是用了内置的deferred模块,是Promise模式的一种实现,而我们这里没有讲过,所以我们就不使用这一模式啦. 我们只定义一个Ajax方法,他可以简单的get,po ...

  10. BZOJ 1924 所驼门王的宝藏(强连通分量缩点+DAG最长链)

    思路不是很难,因为宝藏只会在给出的n个点内有,于是只需要在这n个点里面连边,一个点如果能到达另一个点则连一条有向边, 这样用强连通分量缩点后答案就是DAG的最长链. 问题在于暴力建图是O(n^2)的, ...