【bzoj2179】FFT快速傅立叶 FFT模板
2016-06-01 09:34:54
很久很久很久以前写的了。。。
今天又比较了一下效率,貌似手写复数要快很多。
贴一下模板:
- #include<iostream>
- #include<cstdio>
- #include<cstdlib>
- #include<cstring>
- #include<algorithm>
- #include<cmath>
- #include<queue>
- #include<complex>
- #define ll long long
- #define N 500020
- using namespace std;
- int read(){
- int x=,f=;char ch=getchar();
- while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
- while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
- return x*f;
- }
- struct CD{
- double a,b;
- CD(double x=,double y=){a=x;b=y;}
- friend CD operator +(CD n1,CD n2){return CD(n1.a+n2.a,n1.b+n2.b);}
- friend CD operator -(CD n1,CD n2){return CD(n1.a-n2.a,n1.b-n2.b);}
- friend CD operator *(CD n1,CD n2){return CD(n1.a*n2.a-n1.b*n2.b,n1.a*n2.b+n1.b*n2.a);}
- };
- int n,m,bit=;
- const long double Pi=acos(-1.0);
- void FFT(CD *a,int n,int type){
- for(int i=,j=;i<n;i++) {
- if(j>i)swap(a[i],a[j]);
- int k=n;
- while(j&(k >>= ))j&=~k;
- j|=k;
- }
- for(int i=;i<=bit;i++){
- CD w_n(cos(*type*Pi/(<<i)),sin(*type*Pi/(<<i)));
- for(int j=;j<(<<bit);j+=(<<i)){
- CD w(,);
- for(int k=j;k<j+(<<(i-));k++){
- CD tmp=a[k],tt=w*a[k+(<<(i-))];
- a[k]=a[k]+tt;
- a[k+(<<(i-))]=tmp-tt;
- w=w*w_n;
- }
- }
- }
- if(type<) for(int i=;i<(<<bit);i++) a[i].a=(a[i].a+0.5)/(<<bit);
- }
- CD poly1[N],poly2[N];
- int c[N*];
- char ch[N];
- int main (){
- n=read();
- scanf("%s",ch+);
- for(int i=;i<n;i++)poly1[i]=(double)(ch[n-i]-'');
- scanf("%s",ch+);
- for(int i=;i<n;i++)poly2[i]=(double)(ch[n-i]-'');
- bit=;
- while(<<bit<(n<<))bit++;
- n=<<bit;
- FFT(poly1,n,);FFT(poly2,n,);
- for(int i=;i<n;i++)poly1[i]=poly1[i]*poly2[i];
- FFT(poly1,n,-);
- int jin=,top=;
- for(int i=;i<n;i++){
- jin+=(int)(poly1[i].a+0.5);
- c[++top]=jin%;
- jin/=;
- }
- while(top&&c[top]==) top--;
- while(top)putchar(c[top--]+'');
- return ;
- }
2179: FFT快速傅立叶
Time Limit: 10 Sec Memory Limit: 259 MB
Submit: 2552 Solved: 1299
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
3
4
Sample Output
数据范围:
n<=60000
【bzoj2179】FFT快速傅立叶 FFT模板的更多相关文章
- 【BZOJ 2179】 2179: FFT快速傅立叶 (FFT)
2179: FFT快速傅立叶 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 3308 Solved: 1720 Description 给出两个n位 ...
- bzoj 2179: FFT快速傅立叶 -- FFT
2179: FFT快速傅立叶 Time Limit: 10 Sec Memory Limit: 259 MB Description 给出两个n位10进制整数x和y,你需要计算x*y. Input ...
- BZOJ2179:FFT快速傅立叶(FFT)
Description 给出两个n位10进制整数x和y,你需要计算x*y. Input 第一行一个正整数n. 第二行描述一个位数为n的正整数x. 第三行描述一个位数为n的正整数y. Output 输出 ...
- spoj VFMUL FFT快速傅立叶变换模板题
题意:求两个数相乘. 第一次写非递归的fft,因为一个数组开小了调了两天TAT. #include<iostream> #include<cstring> #include&l ...
- 【bzoj2179】FFT快速傅立叶 FFT
题目描述 给出两个n位10进制整数x和y,你需要计算x*y. 输入 第一行一个正整数n. 第二行描述一个位数为n的正整数x. 第三行描述一个位数为n的正整数y. 输出 输出一行,即x*y的结果. 样例 ...
- BZOJ2179: FFT快速傅立叶 FFT实现高精度乘法
Code: #include <cstdio> #include <algorithm> #include <cmath> #include <cstring ...
- BZOJ 2179 FFT快速傅立叶 ——FFT
[题目分析] 快速傅里叶变换用于高精度乘法. 其实本质就是循环卷积的计算,也就是多项式的乘法. 两次蝴蝶变换. 二进制取反化递归为迭代. 单位根的巧妙取值,是的复杂度成为了nlogn 范德蒙矩阵计算逆 ...
- bzoj 2179 FFT快速傅立叶 —— FFT
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2179 默写板子,注释的是忘记的地方. 代码如下: #include<iostream& ...
- [bzoj2179]FFT快速傅立叶_FFT
FFT快速傅立叶 bzoj-2179 题目大意:给出两个n位10进制整数x和y,你需要计算x*y. 注释:$1\le n\le 6\times 10^4$. 想法: $FFT$入门题. $FFT$实现 ...
随机推荐
- 【JAVA多线程中使用的方法】
一.sleep和wait的区别. 1.wait可以指定时间,也可以不指定. 而sleep必须制定. 2.在同步的时候,对于CPU的执行权和以及锁的处理不同. wait:释放执行权,释放锁. sleep ...
- sort函数用法
原文链接:http://blog.csdn.net/csust_acm/article/details/7326418 sort函数的用法 做ACM题的时候,排序是一种经常要用到的操作.如果每次都自己 ...
- java中常用的工具类(三)
继续分享java中常用的一些工具类.前两篇的文章中有人评论使用Apache 的lang包和IO包,或者Google的Guava库.后续的我会加上的!谢谢支持IT江湖 一.连接数据库的综合类 ...
- HDU5489 Removed Interval(动态规划)
一个长度为n的序列,删除任意长度为l的连续子序列后,求剩下的序列的最长公共子序列. 先求出以第i个元素为开始的LIS的长度,再一次循环,对所要求的结果更新 #include<iostream&g ...
- JavaScript - UnderScore
UnderScore 第一步 call(this) (function() {}.call(this)); 一些简单的初始化操作 (function() { var root = this; var ...
- 配置ogg异构oracle-mysql(3)目的端配置
目的端配置大致分为如下三个步骤:配置mgr,配置checkpoint table,配置应用进程 在目的端先创建一张表,记得带主键: mysql> create database hr;Query ...
- 时间编程,王明学learn
时间编程 一.时间类型 Coordinated Universal Time(UTC):世界标准时间,也就是大家所熟知的格林威治标准时间(Greenwich Mean Time,GMT) Calend ...
- UE对一个很长的字符按16位自动换行
① ②设定16个位 ③ ④结果
- C#分布式缓存Couchbase使用
目前C#业界使用得最多的 Cache 系统主要是 Memcached和 Redis. 这两个 Cache 系统可以说是比较成熟的解决方案,也是很多系统当然的选择. 一.简介 目前C#业界使用得最多的 ...
- Android Fragment学习笔记(二)----Fragment界面添加和管理
Fragment界面添加 了解过fragment的生命周期等简单知识,于是去看官方文档来了解更多相关内容,要添加fragment到我们的UI界面中,给出了两种常用的方法,第一个是在activity的布 ...