2017 多校3 hdu 6061 RXD and functions(FFT)

题意:

给一个函数\(f(x)=\sum_{i=0}^{n}c_i \cdot x^{i}\)

求\(g(x) = f(x - \sum a_i)\)后每一项\(x^{i}\)的系数mod998244353

\(n <= 10^{5},m <= 10^{5}\)

\(0 <= c_i < 998244353\)

\(0 <= a_i < 998244353\)

思路:

令\(d = -\sum a_i\),把\(g(x)\)展开得:

\[g(x) = c_0 (x + d)^{0} + c_1 (x + d)^{1} + ... + c_n (x+d)^{n}
\]

令\(a_i = d^{i}\),再用二项式定理化简一下可以得到

\[g(x) = \sum_{i = 0}^{n}x^{i}\sum_{k=i}^{n}C(k,i)c_ka_{k-i}
\]

\(fft\)只是入了门,想了半天,看不出来这是个卷积式子,组合数会变化啊,赛后终于开窍组合数是个阶乘啊,把\(c_k 和 a^{k-i}变换一下\)

令$$b_k = c_k \cdot k!, a_i = \frac{a_i}{i!}$$

\(g(x)\)就可以写成

\[g(x) = \sum_{i = 0}^{n}x^{i} \cdot \frac{1}{i!}\sum_{k=i}^{n}b_ka_{k-i}
\]

令\(ans(i) = \frac{1}{i!} \sum_{k=i}^{n}b_ka_{k-i}\)

把b数组逆序一下

\(ans(i) = \frac{1}{i!}\sum_{k=0}^{n-i}b_{k}a_{n-k-i}\)

类比fft多项式乘法下面\(c_j\)的形式 \(\sum_{k=0}^{n-i}b_{k}a_{n-k-i}\)这一项其实就是\(fft\)之后得到的数组\(c_{n-i}\),最后答案\(ans(i) = \frac{1}{i!} c_{n-i}\)

\(A(x) = \sum_{i=0}^{n}a_ix^{i}\)

\(B(x) = \sum_{i=0}^{n}b_ix^{i}\)

\(C(x) = A(x)B(x) = \sum_{i=0}^{2n}c_ix^{i}\)

\(c_j = \sum_{i=0}^{j}a_ib_{j-i}\)

然后就上板子了,由于是在模意义下的运算,要拿ntt,去找了个板子

不太会用啊,板子上的费马素数是P=(1LL<<55) * 5+1,原根g=6的,

开始交了几发,TLE,原来是数组开小了,改完再交RE了,也不知道改了哪里就没RE了,然后WA了,暴力对拍数据,发现是费马素数的锅,乱试了其他的一些费马素数,又想了半天觉得这样不行,本来就是在mod下取的逆元,又在P下做运算,ntt原理也不懂,一脸懵逼,最后我直接把P改成mod试了一下,居然A了,好像给的这个mod本来是就是一个费马素数(1<<23) * 119 + 1,g = 3,而且运气好前面试的费马素数原根刚好是3。

还有疑问就是运算时费马素数应该取多大呢,==再深入学习一下

#include<bits/stdc++.h>
#define LL long long
using namespace std;
const int N = 2e5 + 1000;
const int mod = 998244353;
const LL P = mod;
const LL G = 3;
const int NUM = 23;
int read(){
int x = 0;
char c;
while((c=getchar())<'0'||c>'9');
while(c>='0'&&c<='9')
x=x*10+(c-'0'), c=getchar();
return x;
}
int fac[N],facinv[N];
int n, m;
LL mul(LL x,LL y){
//return (x * y - (LL)(x / (long double)P * y + 1e-3) * P + P) % P;
return x * y % P;
}
LL q_pow(LL a,LL b){
LL res = 1,tmp = a;
while(b){
if(b &1) res = res * tmp % P;
tmp = tmp * tmp % P;
b >>= 1;
}
return res;
}
void init(){
fac[0] = facinv[0] = 1;
for(int i = 1;i < N;i++){
fac[i] = 1LL * i * fac[i-1] % mod;
facinv[i] = 1LL * q_pow(i, mod - 2) * facinv[i - 1] % mod;
}
}
LL wn[NUM];
LL a[2 * N], b[2 * N],c[N];
void GetWn()
{
for(int i = 0; i< NUM; i++)
{
int t = 1 << i;
wn[i] = q_pow(G, (P - 1) / t);
}
}
void Rader(LL a[], int len)
{
int j = len >> 1;
for(int i=1; i<len-1; i++)
{
if(i < j) swap(a[i], a[j]);
int k = len >> 1;
while(j >= k)
{
j -= k;
k >>= 1;
}
if(j < k) j += k;
}
}
void NTT(LL a[], int len, int on)
{
Rader(a, len);
int id = 0;
for(int h = 2; h <= len; h <<= 1)
{
id++;
for(int j = 0; j < len; j += h)
{
LL w = 1;
for(int k = j; k < j + h / 2; k++)
{
LL u = a[k];
LL t = mul(w,a[k + h / 2]);
a[k] = (u + t) % P;
a[k + h / 2] = ((u - t) % P + P) % P;
w = mul(w,wn[id]);
}
}
}
if(on == -1)
{
for(int i = 1; i < len / 2; i++)
swap(a[i], a[len - i]);
LL Inv = q_pow(len, P - 2);
for(int i = 0; i < len; i++)
a[i] = mul(a[i],Inv);
}
}
void Conv(LL a[], LL b[], int n)
{
NTT(a, n, 1);
NTT(b, n, 1);
for(int i = 0; i < n; i++) a[i] = mul(a[i],b[i]);
NTT(a, n, -1);
}
int main()
{
GetWn();
init();
while(scanf("%d",&n) == 1){
for(int i = 0;i <= n;i++) c[i] = read();
int sum = 0;
m = read();
for(int i = 1;i <= m;i++){
int x;
x = read();
sum = (sum - x + mod) % mod;
}
int len = 1;
while(len < 2 * (n + 1)) len <<= 1;
int res = 1;
for(int i = 0;i <= n;i++) {
a[i] = 1LL * res * facinv[i] % mod, res = 1LL * res * sum % mod;
b[i] = c[n - i] * fac[n - i] % mod;
}
for(int i = n + 1;i < len;i++) a[i] = b[i] = 0;
Conv(a,b,len);
for(int i = 0;i <= n;i++) printf("%lld ",a[n - i] * facinv[i] % mod);
printf("\n");
}
return 0;
}

2017 多校3 hdu 6061 RXD and functions的更多相关文章

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

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

  2. 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 ...

  3. HDU 6061 RXD and functions(NTT)

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

  4. HDU 6061 RXD and functions

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

  5. 2017 多校2 hdu 6053 TrickGCD

    2017 多校2 hdu 6053 TrickGCD 题目: You are given an array \(A\) , and Zhu wants to know there are how ma ...

  6. 2017 多校5 hdu 6093 Rikka with Number

    2017 多校5 Rikka with Number(数学 + 数位dp) 题意: 统计\([L,R]\)内 有多少数字 满足在某个\(d(d>=2)\)进制下是\(d\)的全排列的 \(1 & ...

  7. 2017 Multi-University Training Contest - Team 3 RXD and functions(NTT)

    题解: 我是参考的 http://blog.csdn.net/qq_32570675/article/details/76571666 这一篇 orz 原来可以这么变换,涨姿势 代码: #includ ...

  8. HDU 6060 - RXD and dividing | 2017 Multi-University Training Contest 3

    /* HDU 6060 - RXD and dividing [ 分析,图论 ] | 2017 Multi-University Training Contest 3 题意: 给一个 n 个节点的树, ...

  9. HDU 6063 - RXD and math | 2017 Multi-University Training Contest 3

    比赛时候面向过题队伍数目 打表- - 看了题解发现确实是这么回事,分析能力太差.. /* HDU 6063 - RXD and math [ 数学,规律 ] | 2017 Multi-Universi ...

随机推荐

  1. 在线代码编辑器 Codemirror 的轻量级 React 组件

    代码编辑器 CodeMirror 的轻量级 React 组件 demo @uiw-react.github.io/react-codemirror/ 特性:

  2. 通过tomcat配置访问本机资源

    背景:在最近的项目中使用海康威视的摄像机,在项目预算中没有购买对应的硬盘录像机,但是由于客户需要能够进行视频的回放功能,所以直接采用了海康提供的视频管理客户端直接进行视频录像,然后保存在本机进行播放. ...

  3. Shell学习——数值运算

    在Bash shell中,可以利用let.(( )).[]执行基本的算术操作,在高级操作时,使用expr和bc两个工具1.let[root@client02 ~]# no1=4[root@client ...

  4. dts--tests(一)

    cmdline.py """ DPDK Test suite. Test cmdline. """ import utils from te ...

  5. react native "Unable to resolve module `AccessibilityInfo`

    error: bundling failed: "Unable to resolve module `AccessibilityInfo` from `/Users/apple/Websto ...

  6. Flask初学者:视图函数/方法返回值(HTML模板/Response对象)

    返回HTML模板:使用“from flask import render_template”,在函数中传入相对于文件夹“templates”HTML模板路径名称字符串即可(默认模板路径),flask会 ...

  7. paramiko基本操作

    paramiko 是一个用作远程控制的模块,它遵循SSH2协议,支持以加密和认证的方式来进行远程服务器的连接.操作.上传和下载. 官方文档地址:http://docs.paramiko.org/ pa ...

  8. POJ:3320-Jessica's Reading Problem(尺取法)

    Jessica's Reading Problem Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 15224 Accepted: ...

  9. poj 2579 中位数问题 查找第K大的值

    题意:对列数X计算∣Xi – Xj∣组成新数列的中位数. 思路:双重二分搜索 对x排序 如果某数大于 mid+xi 说明在mid后面,这些数的个数小于 n/2 的话说明这个中位数 mid 太大 反之太 ...

  10. Leetcode 337. 打家劫舍 III

    题目链接 https://leetcode.com/problems/house-robber-iii/description/ 题目描述 在上次打劫完一条街道之后和一圈房屋后,小偷又发现了一个新的可 ...