HDU 1402 A * B Problem Plus (FFT模板题)
FFT模板题,求A*B。
用次FFT模板需要注意的是,N应为2的幂次,不然二进制平摊反转置换会出现死循环。
取出结果值时注意精度,要加上eps才能A。
- #include <cstdio>
- #include <cstring>
- #include <cmath>
- #include <algorithm>
- using namespace std;
- typedef long long ll;
- const double pi = acos(-1.0);
- const int maxn = 50000 + 5;
- const double eps = 1e-6;
- struct Complex {
- double a, b;
- Complex() {
- }
- Complex(double a, double b) :
- a(a), b(b) {
- }
- Complex operator +(const Complex& t) const {
- return Complex(a + t.a, b + t.b);
- }
- Complex operator -(const Complex& t) const {
- return Complex(a - t.a, b - t.b);
- }
- Complex operator *(const Complex& t) const {
- return Complex(a * t.a - b * t.b, a * t.b + b * t.a);
- }
- };
- // 二进制平摊反转置换
- void brc(Complex *x, int n) {
- int i, j, k;
- for (i = 1, j = n >> 1; i < n - 1; i++) {
- if (i < j)
- swap(x[i], x[j]);
- k = n >> 1;
- while (j >= k) {
- j -= k;
- k >>= 1;
- }
- if (j < k)
- j += k;
- }
- }
- // FFT,其中on==1时为DFT,on==-1时为IDFT
- void FFT(Complex *x, int n, int on) {
- int h, i, j, k, p;
- double r;
- Complex u, t;
- brc(x, n);
- for (h = 2; h <= n; h <<= 1) { // 控制层数
- r = on * 2.0 * pi / h;
- Complex wn(cos(r), sin(r));
- p = h >> 1;
- for (j = 0; j < n; j += h) {
- Complex w(1, 0);
- for (k = j; k < j + p; k++) {
- u = x[k];
- t = w * x[k + p];
- x[k] = u + t;
- x[k + p] = u - t;
- w = w * wn;
- }
- }
- }
- if (on == -1) // IDFT
- for (i = 0; i < n; i++)
- x[i].a = x[i].a / n + eps;
- }
- int n, ma, N;
- Complex x1[maxn<<2], x2[maxn<<2];
- char sa[maxn], sb[maxn];
- int ans[maxn<<1];
- void solve() {
- int n1 = strlen(sa), n2 = strlen(sb);
- int N = 1, tmpn = max(n1, n2) << 1;
- // N应为2的幂次
- while(N < tmpn) N <<= 1;
- for(int i = 0;i < N; i++)
- x1[i].a = x1[i].b = x2[i].a = x2[i].b = 0;
- for(int i = 0;i < n1; i++)
- x1[i].a = sa[n1-i-1] - '0';
- for(int i = 0;i < n2; i++)
- x2[i].a = sb[n2-i-1] - '0';
- FFT(x1, N, 1); FFT(x2, N, 1);
- for(int i = 0;i < N; i++)
- x1[i] = x1[i]*x2[i];
- FFT(x1, N, -1);
- int pre = 0, top = 0;
- for(int i = 0;i < n1+n2; i++) {
- // 不加epsA不了~
- int cur = (int)(x1[i].a + eps);
- ans[++top] = (cur + pre)%10;
- pre = (pre + cur)/10;
- }
- while(!ans[top] && top > 1) top--;
- for(int i = top;i >= 1; i--)
- printf("%d", ans[i]);
- puts("");
- }
- int main() {
- while(scanf("%s%s", sa, &sb) != -1) {
- solve();
- }
- return 0;
- }
HDU 1402 A * B Problem Plus (FFT模板题)的更多相关文章
- HDU - 1402 A * B Problem Plus FFT裸题
http://acm.hdu.edu.cn/showproblem.php?pid=1402 题意: 求$a*b$ 但是$a$和$b$的范围可以达到 $1e50000$ 题解: 显然...用字符串模拟 ...
- hdu 1402 A * B Problem Plus FFT
/* hdu 1402 A * B Problem Plus FFT 这是我的第二道FFT的题 第一题是完全照着别人的代码敲出来的,也不明白是什么意思 这个代码是在前一题的基础上改的 做完这个题,我才 ...
- HDU 1402 A * B Problem Plus (FFT求高精度乘法)
A * B Problem Plus Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
- HDU - 1402 A * B Problem Plus (FFT实现高精度乘法)
题意:计算A*B,A,B均为长度小于50000的整数. 这是FFT在大整数相乘中的一个应用,我本来想用NTT做的,但NTT由于取模很可能取炸,所以base必须设得很小,而且效率也比不上FFT. A和B ...
- [hdu1402]A * B Problem Plus(FFT模板题)
解题关键:快速傅里叶变换fft练习. 关于结果多项式长度的确定,首先将短多项式扩展为长多项式,然后扩展为两倍. #include<cstdio> #include<cstring&g ...
- HDU 5832 A water problem(某水题)
p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...
- hdu 1402 A * B Problem Plus (FFT模板)
A * B Problem Plus Problem Description Calculate A * B. Input Each line will contain two integers A ...
- HDU 1402 A * B Problem Plus(FFT)
Problem Description Calculate A * B. Input Each line will contain two integers A and B. Process to ...
- 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 ...
随机推荐
- wsdl文件结构分析
WSDL (Web Services Description Language,Web服务描述语言)是一种XML Application,他将Web服务描述定义为一组服务访问点,客户端可以通过这些服务 ...
- SURF特征
了解了SIFT特征后,来学习SURF特征. 虽说是SIFT的一个变种,可是跟SIFT还是有差别的 差别有例如以下: 1.尺度空间的构建(近似)不同. 2.同意尺度空间多层图像同一时候被处理 3.特征点 ...
- 自定义ImageView实现图片手势滑动,多点触摸放大缩小效果
首先呢,还是一贯作风,我们先来看看众多应用中的示例:(这种效果是很常见的,可以说应用的必须品.) 搜狐客户端 ...
- javascript封装id|class|元素选择器
由于各个浏览器都支持的选择方法只有如下三种: 1 document.getElementById() 2 document.getElementsByName() 3 document.getElem ...
- Entrez检索实例 - NCBI
题目:已知来豆荚斑驳病毒(bean pod mottle virus,BPMV)的名字,查询BPMV基因组信息.核酸序列信息.蛋白序列信息和结构信息 解答: 1.直接搜索,点genome,即可看到病毒 ...
- 内容提供者 ContentResolver 数据库 示例 -2
MainActivity public class MainActivity extends ListActivity { // 访问内容提供者时需要的主机名称 public stat ...
- JavaScript原型,原型链 !
js原型 问题:什么是js原型? js每声明一个function,都有prototype原型,prototype原型是函数的一个默认属性,在函数的创建过程中由js编译器自动添加. 也就是说:当生产一个 ...
- 10个最实用的Linux命令
收集了一些对于Linux新手最基本但最有用的Linux命令.你完全可以键入这些命令来管理你的服务器.这些命令对于学习vps或服务器管理的新手最为简便.1.List命令 ls -a //列出所有文件 l ...
- C#进程与线程
public Form1() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { / ...
- php 之 PDO数据访问抽象层(0513)
PDO(PHP Data Objects)是一种在PHP里连接数据库的使用接口. PDO与mysqli曾经被建议用来取代原本PHP在用的mysql相关函数, 基于数据库使用的安全性,因为后者欠缺对于S ...