spoj VFMUL FFT快速傅立叶变换模板题
题意;求两个数相乘。
第一次写非递归的fft,因为一个数组开小了调了两天TAT。
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
#include<cmath>
using namespace std;
#define PI 3.1415926535897932384
#define MAXN 1200000
#pragma optimize("O2")
struct Complex
{
double x,y;
Complex(){};
Complex(double x,double y):x(x),y(y){};
void init(double x,double y)
{
this->x=x;this->y=y;
}
Complex operator +(Complex a)
{
Complex ret(x + a.x, y + a.y);
return ret;
}
Complex operator -(Complex a)
{
Complex ret(x - a.x, y - a.y);
return ret;
}
Complex operator *(Complex a)
{
Complex ret(x*a.x - y*a.y, x*a.y + y*a.x);
return ret;
}
Complex operator /(double v)
{
Complex ret(x/v,y/v);
return ret;
}
Complex operator =(double x)
{
this->x=x;
return *this;
}
void operator -=(Complex a)
{
this->x-=a.x;
this->y-=a.y;
}
void operator +=(Complex a)
{
this->x+=a.x;
this->y+=a.y;
}
};
char ss[MAXN];
int t1[MAXN],t2[MAXN];
int pp[MAXN];
Complex ww[MAXN][];
Complex g1[MAXN],g2[MAXN];
long long res[MAXN];
int n;
void dft(Complex g[],int len,int sign)
{
Complex t;
for (int i=;i<len;i<<=)
{
for (int j=;j<len;j+=(i<<))
{
for (int k=;k<i;k++)
{
t=g[j+k];
g[j+k]=g[j+k]+g[j+k+i]*ww[k*((n>>)/i)][sign];
g[j+k+i]=t-g[j+k+i]*ww[k*((n>>)/i)][sign];
}
}
}
} int main()
{
freopen("input.txt","r",stdin);
// freopen("output.txt","w",stdout);
int i,j,k,x,y,z,m;
int n1,n2;
int nn;
scanf("%d",&nn);
while (nn--)
{ scanf("%s",ss);
m=strlen(ss);
for (i=;i<m;i++)
t1[(m-i-)/]=t1[(m-i-)/]*+ss[i]-'';
n1=(m-)/+;
scanf("%s",ss);
m=strlen(ss);
for (i=;i<m;i++)
t2[(m-i-)/]=t2[(m-i-)/]*+ss[i]-'';
n2=(m-)/+;
n=max(n1,n2);
while (n!=(n&(-n)))n-=n&(-n);
n<<=;
for (i=;i<n;i++)
for (j=n>>,x=;j;j>>=,x<<=)
if (i&j)pp[i]+=x;
for (i=;i<n1;i++)g1[pp[i]].x=t1[i];
for (i=;i<n2;i++)g2[pp[i]].x=t2[i];
for (i=;i<=n;i++)
{
ww[i][].init(cos(*PI*i/n), -sin(*PI*i/n));
ww[i][].x=ww[i][].x;
ww[i][].y=-ww[i][].y;
}
dft(g1,n,);
dft(g2,n,);
for (i=;i<n;i++)g2[i]=g1[i]*g2[i];
for (i=;i<n;i++)g1[pp[i]]=g2[i];
dft(g1,n,);
for (i=;i<n;i++)res[i]=(long long)(g1[i].x/n+0.5);
for (i=;i<n;i++)res[i+]+=res[i]/,res[i]%=;
m=n;
while (m && !res[m-])m--;
printf("%d",(int)res[m-]);
for (i=m-;i>=;i--)
printf("%05d",(int)res[i]);
printf("\n");
memset(t1,,sizeof(t1[])*n);
memset(t2,,sizeof(t2[])*n);
memset(pp,,sizeof(pp[])*n);
memset(res,,sizeof(res[])*n);
memset(g1,,sizeof(g1[])*n);
memset(g2,,sizeof(g2[])*n);
}
}
spoj VFMUL FFT快速傅立叶变换模板题的更多相关文章
- FFT(快速傅立叶变换):HDU 1402 A * B Problem Plus
Calculate A * B. Input Each line will contain two integers A and B. Process to end of file. Note: th ...
- FFT快速傅立叶变换的工作原理
实数DFT,复数DFT,FFTFFT是计算DFT的快速算法,但是它是基于复数的,所以计算实数DFT的时候需要将其转换为复数的格式,下图展示了实数DFT和虚数DFT的情况,实数DFT将时域中N点信号转换 ...
- FFT快速傅立叶变换
//最近突然发现博客园支持\(\rm\LaTeX\),非常高兴啊! 话说离省选只有不到五天了还在学新东西确实有点逗…… 切到正题,FFT还是非常神奇的一个东西,能够反直觉地把两个多项式相乘的时间复杂度 ...
- FFT快速傅立叶变换:解析wav波频图、Time Domain、Frequency Domain
您好,此教程将教大家使用scipy.fft分析wav文件的波频图.Time Domain.Frequency Domain. 实际案例:声音降噪,去除高频. 结果: 波频图: Time Domain:
- 【bzoj2179】FFT快速傅立叶 FFT模板
2016-06-01 09:34:54 很久很久很久以前写的了... 今天又比较了一下效率,貌似手写复数要快很多. 贴一下模板: #include<iostream> #include& ...
- 离散傅立叶变换与快速傅立叶变换(DFT与FFT)
自从去年下半年接触三维重构以来,听得最多的词就是傅立叶变换,后来了解到这个变换在图像处理里面也是重点中的重点. 本身自己基于高数知识的理解是傅立叶变换是将一个函数变为一堆正余弦函数的和的变换.而图像处 ...
- 快速傅立叶变换(FFT)算法
已知多项式f(x)=a0+a1x+a2x2+...+am-1xm-1, g(x)=b0+b1x+b2x2+...+bn-1xn-1.利用卷积的蛮力算法,得到h(x)=f(x)g(x),这一过程的时间复 ...
- $\mathcal{FFT}$·$\mathcal{Fast \ \ Fourier \ \ Transformation}$快速傅立叶变换
\(2019.2.18upd:\) \(LINK\) 之前写的比较适合未接触FFT的人阅读--但是有几个地方出了错,大家可以找一下233 啊-本来觉得这是个比较良心的算法没想到这么抽搐这个算法真是将一 ...
- BZOJ 2194 快速傅立叶变换之二 | FFT
BZOJ 2194 快速傅立叶变换之二 题意 给出两个长为\(n\)的数组\(a\)和\(b\),\(c_k = \sum_{i = k}^{n - 1} a[i] * b[i - k]\). 题解 ...
随机推荐
- Spring MVC 3.0.5+Spring 3.0.5+MyBatis3.0.4全注解实例详解(四)
这一章大象将详细分析web层代码,以及使用Spring MVC的注解及其用法和其它相关知识来实现控制器功能. 之前在使用Struts2实现MVC的注解时,是借助struts2-conventi ...
- Java基础知识强化之IO流笔记37:FileReader/FileWriter(转换流的子类)复制文本文件案例
1. 转换流的简化写法: 由于我们常见的操作都是使用本地默认编码,所以,不用指定编码.而转换流的名称有点长,所以,Java就提供了其子类供我们使用:FileReader / FileWriterOut ...
- laydate JS日期插件
原文出处 简要介绍 你是时候换一款日期控件了,而layDate非常愿意和您成为工作伙伴.她致力于成为全球最用心的web日期支撑,为国内外所有从事web应用开发的同仁提供力所能及的动力.她基于原生Jav ...
- SQL Server自动化运维系列 - 多服务器数据收集和性能监控
需求描述 在生产环境中,很多情况下需要采集数据,用以定位问题或者形成基线. 关于SQL Server中的数据采集有着很多种的解决思路,可以采用Trace.Profile.SQLdiag.扩展事件等诸多 ...
- Dojo Widget中的全局变量
转自http://blog.163.com/mqsy_yj/blog/static/2940499220121014115338929/ 前期设计了一个清除widget的功能,虽然可以从html文件中 ...
- DLL使用总结
最近项目中使用到了DLL,因此就把最近一段时间的学习总结一下,以备不时之需. 一.相关概念 1.动态链接库 自从微软推出第一个版本的Windows操作系统以来,动态链接库(DLL)一直是Windows ...
- 关于iOS上的静态库
最近再进行项目的真机调试,然后发现了一个天坑.就此研究了一些iOS上的静态库的使用: 首先我们是直接拿一个可以运行的项目来制作静态库的,网上大部分都是先创建静态库然后再写内容,看看我的方法. 1.把子 ...
- js使用正则表达式去空格
写成类的方法格式如下:(str.trim();) <script language="javascript"> String.prototype.trim=functi ...
- 05_Excel操作_01_简单导入导出
[Excel组成] 主要由四部分组成: 1.工作簿 每一个Excel文件都可以看成是一个工作簿,当打开一个Excel文件时,相当于打开了一个Excel工作簿. 2.工作表 当打开了Excel工作簿后, ...
- (zzuli)1907 小火山的宝藏收益
Description 进去宝藏后, 小火山发现宝藏有N个房间,且这n个房间通过N-1道门联通. 每一个房间都有一个价值为Ai的宝藏, 但是每一个房间也都存在一个机关.如果小火山取走了这个房间的宝藏, ...