洛谷P1919 【模板】A*B Problem升级版(FFT快速…
2018-06-17 21:14:42来源:未知 阅读 ()
题目描述
给出两个n位10进制整数x和y,你需要计算x*y。
输入输出格式
输入格式:
第一行一个正整数n。 第二行描述一个位数为n的正整数x。 第三行描述一个位数为n的正整数y。
输出格式:
输出一行,即x*y的结果。(注意判断前导0)
输入输出样例
1 3 4
12
说明
数据范围:
n<=60000
来源:bzoj2179
本题数据为洛谷自造数据,使用CYaRon耗时5分钟完成数据制作。
emmmm感觉学了FFT没什么乱用啊,,
也就来水一水这种板子吧。
思路很简单,将每一位看成多项式的系数。
来一遍FFT
最后去掉前导0
输出
不过话说我的FFT怎么这么慢
#include<iostream> #include<cstdio> #include<cmath> using namespace std; const int MAXN=1e5+10; const double Pi=acos(-1.0); int r[MAXN],l=0,limit=1,c[MAXN]; char sa[MAXN],sb[MAXN]; struct complex { double x,y; complex(double xx=0,double yy=0){x=xx,y=yy;} }a[MAXN],b[MAXN]; 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);} void FFT(complex *a,int type) { for(int i=0;i<limit;i++) if(i<r[i]) swap(a[i],a[r[i]]); for(int mid=1;mid<limit;mid<<=1) { complex Wn(cos(Pi/mid),type*sin(Pi/mid) ); for(int R=mid<<1,j=0;j<limit;j+=R) { complex w(1,0); for(int k=0;k<mid;k++,w=w*Wn) { complex x=a[j+k],y=w*a[j+k+mid]; a[j+k]=x+y; a[j+k+mid]=x-y; } } } } int main() { #ifdef WIN32 freopen("a.in","r",stdin); #else #endif int N; scanf("%d",&N);N--; scanf("%s%s",sa,sb); for(int i=0;i<=N;i++) a[i].x=sa[N-i]-'0',b[i].x=sb[N-i]-'0'; while(limit<=N*2) limit<<=1,l++; for(int i=0;i<=limit;i++) r[i]=(r[i>>1]>>1) | ((i&1)<<(l-1) ); FFT(a,1); FFT(b,1); for(int i=0;i<=limit;i++) a[i]=a[i]*b[i]; FFT(a,-1); for(int i=0;i<=limit;i++) c[i]=(int)(a[i].x/limit+0.5); //for(int i=1;i<=limit;i++) printf("%d ",c[i]);printf("\n"); for(int i=0;i<=limit;i++) { if(c[i]>10) { c[i+1]+=c[i]/10,c[i]%=10; if(i+1>limit) limit++; } } for(int i=limit;i>=0;i--) if(c[i]==0) limit--; else break; for(int i=limit;i>=0;i--) printf("%d",c[i]); return 0; }
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- C++冒泡排序 (基于函数模板实现) 2020-05-31
- C++ 模板类vector 2020-05-31
- C++ 模板类array 2020-05-31
- C++ 模板类vector 2020-05-30
- 洛谷P1164->小A点菜 2020-05-18
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash