BZOJ2194:快速傅立叶之二(FFT)
Description
请计算C[k]=sigma(a[i]*b[i-k]) 其中 k < = i < n ,并且有 n < = 10 ^ 5。 a,b中的元素均为小于等于100的非负整数。
Input
Output
输出N行,每行一个整数,第i行输出C[i-1]。
Sample Input
3 1
2 4
1 1
2 4
1 4
Sample Output
12
10
6
1
Solution

像这样下标和一定的式子就能用FFT进行优化了
下方公式转自https://blog.csdn.net/ycdfhhc/article/details/50636751
因为我不会markdown
一开始我们发现初始式子并不是FFT的形式没法搞
然后我们就将B数组翻转过来,然后发现下标和一定了……
然后把式子用另一个D表示出来,然后就可以FFT了……
答案C(0~n-1)对应D(n-1,n+n-2)
快二轮了感觉没啥希望
Code
- #include<iostream>
- #include<cstring>
- #include<cstdio>
- #include<cmath>
- #define N (400000+100)
- using namespace std;
- double pi=acos(-1.0);
- int n,fn,l,r[N];
- struct complex
- {
- double x,y;
- complex (double xx=,double yy=)
- {
- x=xx; y=yy;
- }
- }a[N],b[N];
- complex operator + (complex a,complex b){return complex(a.x+b.x,a.y+b.y);}
- complex operator - (complex a,complex b){return complex(a.x-b.x,a.y-b.y);}
- complex operator * (complex a,complex b){return complex(a.x*b.x-a.y*b.y,a.x*b.y+a.y*b.x);}
- complex operator / (complex a,double b){return complex(a.x/b,a.y/b);}
- void FFT(int n,complex *a,int opt)
- {
- for (int i=; i<n; ++i)
- if (i<r[i])
- swap(a[i],a[r[i]]);
- for (int k=; k<n; k<<=)
- {
- complex wn=complex(cos(pi/k),opt*sin(pi/k));
- for (int i=; i<n; i+=(k<<))
- {
- complex w=complex(,);
- for (int j=; j<k; ++j,w=w*wn)
- {
- complex x=a[i+j], y=w*a[i+j+k];
- a[i+j]=x+y; a[i+j+k]=x-y;
- }
- }
- }
- if (opt==-) for (int i=; i<n; ++i) a[i]=a[i]/n;
- }
- int main()
- {
- scanf("%d",&n); n--;
- for (int i=; i<=n; ++i)
- scanf("%lf%lf",&a[i].x,&b[n-i].x);
- fn=;
- while (fn<=n+n) fn<<=, l++;
- for (int i=; i<fn; ++i)
- r[i]=(r[i>>]>>) | ((i&)<<(l-));
- FFT(fn,a,); FFT(fn,b,);
- for (int i=; i<=fn; ++i)
- a[i]=a[i]*b[i];
- FFT(fn,a,-);
- for (int i=n; i<=n+n; ++i)
- printf("%d\n",(int)(a[i].x+0.5));
- }
BZOJ2194:快速傅立叶之二(FFT)的更多相关文章
- bzoj2194 快速傅立叶之二 ntt
bzoj2194 快速傅立叶之二 链接 bzoj 思路 对我这种和式不强的人,直接转二维看. 发现对\(C_k\)贡献的数对(i,j),都是右斜对角线. 既然贡献是对角线,我们可以利用对角线的性质了. ...
- [bzoj2194]快速傅立叶之二_FFT
快速傅立叶之二 bzoj-2194 题目大意:给定两个长度为$n$的序列$a$和$b$.求$c$序列,其中:$c_i=\sum\limits_{j=i}^{n-1} a_j\times b_{j-i} ...
- bzoj 2194: 快速傅立叶之二 -- FFT
2194: 快速傅立叶之二 Time Limit: 10 Sec Memory Limit: 259 MB Description 请计算C[k]=sigma(a[i]*b[i-k]) 其中 k & ...
- 2018.11.18 bzoj2194: 快速傅立叶之二(fft)
传送门 模板题. 将bbb序列反过来然后上fftfftfft搞定. 代码: #include<bits/stdc++.h> #define ri register int using na ...
- 【bzoj2194】快速傅立叶之二 FFT
题意:给定序列a,b,求序列c,\(c(k)=\sum_{i=k}^{n-1}a(i)b(i-k)\) Solution: \[ c(k)=\sum_{i=k}^{n-1}a(i)b(i-k)\\ c ...
- BZOJ2194 快速傅立叶之二 【fft】
题目 请计算C[k]=sigma(a[i]*b[i-k]) 其中 k < = i < n ,并且有 n < = 10 ^ 5. a,b中的元素均为小于等于100的非负整数. 输入格式 ...
- bzoj2194: 快速傅立叶之二
#include <iostream> #include <cstdio> #include <cstring> #include <cmath> #i ...
- bzoj千题计划256:bzoj2194: 快速傅立叶之二
http://www.lydsy.com/JudgeOnline/problem.php?id=2194 相乘两项的下标 的 差相同 那么把某一个反过来就是卷积形式 fft优化 #include< ...
- BZOJ.2194.快速傅立叶之二(FFT 卷积)
题目链接 \(Descripiton\) 给定\(A[\ ],B[\ ]\),求\[C[k]=\sum_{i=k}^{n-1}A[i]*B[i-k]\ (0\leq k<n)\] \(Solut ...
随机推荐
- WES7 定制界面完整过程(去除所有windows标识)
转载但有改动 红色字体记录 目的:实验从启动开始到出现桌面,不出现任何windows图标或标识.重大提示:在某些虚拟机上面操作和真实机器是不一样的,主机会容易很多;所以在虚拟机无法实现效果的时候使用主 ...
- group by 语句
user E_book go 这样的程序会出错,因为play没有使用sum,所以要分组. group by play 有函数的和没有函数的表一起使用要用 GROUP BY .AVG 求平均值,只能与数 ...
- SpringBoot 开启debug
项目基于gradle ,今天想断点debug一下springboot,查阅资料后,纪录一下步骤. 创建Remote 创建gradle.properities 在当前项目下创建gradle.proper ...
- MySQL中文问题
-- 设置客户端显示字符集 mysql>set names utf8; -- 建表时设置表的字符集和引擎 CREATE TABLE table ( `abc` char(32) NOT NULL ...
- jdk动态代理与cglib代理、spring Aop代理原理-代理使用浅析
原创声明:本博客来源为本人原创作品,绝非他处摘取,转摘请联系博主 代理(proxy)的定义:为某对象提供代理服务,拥有操作代理对象的功能,在某些情况下,当客户不想或者不能直接引用另一个对象,而代理对象 ...
- jquery获取下拉框中的循环值
<select class="test" id="projectno" name="projectno"> <option ...
- SPOJ2666 QTREE4
我是萌萌的传送门 我是另一个萌萌的传送门 一道树分治……简直恶心死了……我在调代码的时候只想说:我*************************************************…… ...
- 001Spring 定时任务 Scheduled
01.@Scheduled注解参数 @Scheduled支持fixedRate.fixedDelay.cron表达式参数.其中,fixedRate和fixedDelay没有区别,都是启动时执行1次,每 ...
- Spark企业级应用开发和调优
1.Spark企业级应用开发和调优 Spark项目编程优化历程记录,主要介绍了Spark企业级别的开发过程中面临的问题和调优方法.包含合理分配分片,避免计算中间结果(大数据量)的collect,合理使 ...
- Oracle基础之分析表
analyze table tablename compute statistics; analyze index indexname compute statistics; (analyze 不会重 ...