【BZOJ】2194: 快速傅立叶之二
http://www.lydsy.com/JudgeOnline/problem.php?id=2194
题意:求$c[k]=\sum_{k<=i<n} a[i]b[i-k], n<=10^5$
#include <bits/stdc++.h>
using namespace std;
struct cp {
double x, y;
cp(double _x=0, double _y=0):x(_x),y(_y) {}
cp operator+(const cp &a) { return cp(x+a.x, y+a.y); }
cp operator-(const cp &a) { return cp(x-a.x, y-a.y); }
cp operator*(const cp &a) { return cp(x*a.x-y*a.y, x*a.y+y*a.x); }
};
const int N=400005;
const double pi=acos(-1);
int rev[N];
void dft(cp *a, int n, int flag) {
static cp A[N], u, v;
static int i, j, m, mid;
for(i=0; i<n; ++i) A[rev[i]]=a[i];
for(i=0; i<n; ++i) a[i]=A[i];
for(m=2; m<=n; m<<=1) {
cp wn(cos(pi*2/m), sin(pi*2/m)*flag);
for(i=0; i<n; i+=m) {
mid=m>>1; cp w(1);
for(j=0; j<mid; ++j) {
u=a[i+j], v=a[i+j+mid]*w;
a[i+j]=u+v;
a[i+j+mid]=u-v;
w=w*wn;
}
}
}
if(flag==-1) for(i=0; i<n; ++i) a[i].x/=n;
}
inline void init(int &len) {
static int k, t, j, r; k=1; t=0;
while(k<len) k<<=1, ++t;
len=k;
for(int i=0; i<len; ++i) {
k=i; j=t; r=0;
while(j--) r<<=1, r|=k&1, k>>=1;
rev[i]=r;
}
}
void fft(int *a, int *b, int *c, int la, int lb) {
static cp x[N], y[N];
int len=la+lb-1;
init(len);
for(int i=0; i<len; ++i) x[i].x=a[i], x[i].y=0;
for(int i=0; i<len; ++i) y[i].x=b[i], y[i].y=0;
dft(x, len, 1); dft(y, len, 1);
for(int i=0; i<len; ++i) x[i]=x[i]*y[i];
dft(x, len, -1);
for(int i=0; i<len; ++i) c[i]=x[i].x+0.5;
}
int x[N], y[N], a[N], n;
int main() {
scanf("%d", &n);
for(int i=0; i<n; ++i) scanf("%d%d", &x[i], &y[i]);
for(int i=0; i<n; ++i) a[i]=x[n-1-i];
fft(y, a, x, n, n);
for(int i=0; i<n; ++i) a[i]=x[n-1-i];
for(int i=0; i<n; ++i) printf("%d\n", a[i]);
return 0;
}
复习了下fft...能码出来真是极好的= =可是为什么我的fft辣么慢!
首先是很复杂的代换= =
$$
\begin{align}
c[k]
= & \sum_{k<=i<n} a[i]b[i-k] \\
= & \sum_{0<=i-k<=n-k-1} a[i]b[i-k] \\
\end{align}
$$
令$j=i-k, 则i=j+k$
$$ c[k] = \sum_{0<=j<=n-k-1} a[j+k]b[j] $$
设 $ c'[n-k-1]=c[k] , T=n-k-1 \Rightarrow k=n-1-T $,有
$$ c'[T] = \sum_{0<=j<=T} a[n-1-(T-j)]b[j] $$
最后再设 $ a'[T-j]=a[n-1-(T-j)] \Rightarrow a'[x]=a[n-1-x] $
然后就是裸的卷积辣= =
【BZOJ】2194: 快速傅立叶之二的更多相关文章
- bzoj 2194: 快速傅立叶之二 -- FFT
2194: 快速傅立叶之二 Time Limit: 10 Sec Memory Limit: 259 MB Description 请计算C[k]=sigma(a[i]*b[i-k]) 其中 k & ...
- bzoj 2194 快速傅立叶之二 —— FFT
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2194 如果把 a 序列翻转,则卷积得到的是 c[n-i],再把得到的 c 序列翻转即可. 代 ...
- [BZOJ]2194: 快速傅立叶之二
题目大意:给定序列a,b,求序列c满足c[k]=sigma(a[i]*b[i-k]) (k<=i<n).(n<=10^5) 思路:观察发现就是普通的卷积反一反(翻转ab其中一个后做卷 ...
- 【刷题】BZOJ 2194 快速傅立叶之二
Description 请计算C[k]=sigma(a[i]*b[i-k]) 其中 k < = i < n ,并且有 n < = 10 ^ 5. a,b中的元素均为小于等于100的非 ...
- BZOJ.2194.快速傅立叶之二(FFT 卷积)
题目链接 \(Descripiton\) 给定\(A[\ ],B[\ ]\),求\[C[k]=\sum_{i=k}^{n-1}A[i]*B[i-k]\ (0\leq k<n)\] \(Solut ...
- BZOJ 2194 快速傅立叶之二 ——FFT
[题目分析] 咦,这不是卷积裸题. 敲敲敲,结果样例也没过. 看看看,卧槽i和k怎么反了. 艹艹艹,把B数组取个反. 靠靠靠,怎么全是零. 算算算,最终的取值范围算错了. 交交交,总算是A掉了. [代 ...
- bzoj 2194: 快速傅立叶之二【NTT】
看别的blog好像我用了比较麻烦的方法-- (以下的n都--过 \[ c[i]=\sum_{j=i}^{n}a[i]*b[j-i] \] 设j=i+j \[ c[i]=\sum_{j=0}^{n-i} ...
- BZOJ 2194 快速傅立叶变换之二 | FFT
BZOJ 2194 快速傅立叶变换之二 题意 给出两个长为\(n\)的数组\(a\)和\(b\),\(c_k = \sum_{i = k}^{n - 1} a[i] * b[i - k]\). 题解 ...
- 【BZOJ 2194】2194: 快速傅立叶之二(FFT)
2194: 快速傅立叶之二 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 1273 Solved: 745 Description 请计算C[k]= ...
随机推荐
- SQL 参数,传入参数和自己申明参数——异常抛出
ALTER PROCEDURE [dbo].[OA_RemoveProject] @Password nvarchar(30), --这是传入的参数 @ProjectNo nvarchar(8) AS ...
- Delphi面向对象的方法
方法是属于一个给定对象的过程和函数,方法反映的是对象的行为而不是数据,前一篇提到的对象的两个重要的方法:构造方法和析构方法. 为了使对象能执行各种功能,你能在对象中定制方法 创建一个方法用两个步骤,首 ...
- Bootstrap 表格 笔记
Bootstrap 表格 Bootstrap 提供了一个清晰的创建表格的布局.下表列出了 Bootstrap 支持的一些表格元素: 标签 描述 <table> 为表格添加基础样式. < ...
- Java Hour 65 [译] Java 6.0 说明
原文可爱的地址: http://www.javabeat.net/introduction-to-java-6-0-new-features-part-i/ 该文字2007年的,现在估计老掉牙了,但是 ...
- android 入门-Activity及 字体
private Button sButton; private TextView mTextView; private Button fButton; ,,,,}; @Override protect ...
- 开心网的账号登录及api操作
.kaixin.php <?php /** * PHP Library for kaixin001.com * * @author */ class kaixinPHP { function _ ...
- hdu 4273 2012长春赛区网络赛 三维凸包中心到最近面距离 ***
新模板 /* HDU 4273 Rescue 给一个三维凸包,求重心到表面的最短距离 模板题:三维凸包+多边形重心+点面距离 */ #include<stdio.h> #include&l ...
- PMP 第三章 单个项目的项目管理标准
1 项目管理五大过程组分别是什么? 启动过程组 规划过程组 执行过程组 监控过程组 收尾过程组 2 启动项目组是干什么?包含哪些过程?每个阶段都需要启动吗? 启动过程组:获得授权,定义一个新项目或现有 ...
- linux系统定时任务
crontab常用的几个命令如下 sudo crontab -l #显示所有的定时任务 sudo crontab -e #编辑任务 sudo crontab -r #删除所有的任务 编辑任务时的书写方 ...
- ArrayList集合&特殊集合
一.ArrayList集合 集合内可以放不同类型的元素 另:object类型为所有数据类型的基类 添加元素:.add(); 清空集合:al.clear(); 克隆集合:.clone(); 判断是否包含 ...