转载来源:https://blog.csdn.net/zj_whu/article/details/72954766

#include <cstdio>

#include <cmath>

#include <complex>

#include <cstring>

using namespace std;

const double PI(acos(-1.0));

typedef complex<double> C;

const int N = (1 << 20);

int ans[N];

C a[N], b[N];

char s[N], t[N];

void bit_reverse_swap(C* a, int n) {

  for (int i = 1, j = n >> 1, k; i < n - 1; ++i) {

    if (i < j) swap(a[i], a[j]);

    // tricky

    for (k = n >> 1; j >= k; j -= k, k >>= 1)  // inspect the highest "1"

      ;

    j += k;

  }

}

void FFT(C* a, int n, int t) {

  bit_reverse_swap(a, n);

  for (int i = 2; i <= n; i <<= 1) {

    C wi(cos(2.0 * t * PI / i), sin(2.0 * t * PI / i));

    for (int j = 0; j < n; j += i) {

      C w(1);

      for (int k = j, h = i >> 1; k < j + h; ++k) {

        C t = w * a[k + h], u = a[k];

        a[k] = u + t;

        a[k + h] = u - t;

        w *= wi;

      }

    }

  }

  if (t == -1) {

    for (int i = 0; i < n; ++i) {

      a[i] /= n;

    }

  }

}

int trans(int x) {

  return 1 << int(ceil(log(x) / log(2) - 1e-9));  // math.h/log() 以e为底

}

int main() {

  //  freopen("test0.in","r",stdin);

  // freopen("test0b.out","w",stdout);

  int n, m, l;

  for (; ~scanf("%s%s", s, t);) {

    n = strlen(s);

    m = strlen(t);

    l = trans(n + m - 1);  // n次*m次不超过n+m-1次

    for (int i = 0; i < n; ++i) a[i] = C(s[n - 1 - i] - '0');

    for (int i = n; i < l; ++i) a[i] = C(0);

    for (int i = 0; i < m; ++i) b[i] = C(t[m - 1 - i] - '0');

    for (int i = m; i < l; ++i) b[i] = C(0);

FFT(a, l, 1);  //把A和B换成点值表达

    FFT(b, l, 1);

    for (int i = 0; i < l; ++i)  //点值做乘法

      a[i] *= b[i];

    FFT(a, l, -1);  //逆DFT

    for (int i = 0; i < l; ++i) ans[i] = (int)(a[i].real() + 0.5);

    ans[l] = 0;  // error-prone :'l' -> '1'

    for (int i = 0; i < l; ++i) {

      ans[i + 1] += ans[i] / 10;

      ans[i] %= 10;

    }

    int p = l;

    for (; p && !ans[p]; --p)

      ;

    for (; ~p; putchar(ans[p--] + '0'))

      ;

        puts("");

    }

    return 0;

}

FFT用于高效大数乘法(当模板用)的更多相关文章

  1. 51nod 1027大数乘法

    题目链接:51nod 1027大数乘法 直接模板了. #include<cstdio> #include<cstring> using namespace std; ; ; ; ...

  2. [hdu1402]大数乘法(FFT模板)

    题意:大数乘法 思路:FFT模板 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 ...

  3. ACM学习历程—51NOD1028 大数乘法V2(FFT)

    题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1028 题目大意就是求两个大数的乘法. 但是用普通的大数乘法,这 ...

  4. 1028 大数乘法 V2(FFT or py)

    1028 大数乘法 V2 基准时间限制:2 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 给出2个大整数A,B,计算A*B的结果.   Input 第1行:大数A 第2行:大数B ...

  5. Java 大数、高精度模板

    介绍: java中用于操作大数的类主要有两个,一个是BigInteger,代表大整数类用于对大整数进行操作,另一个是BigDecimal,代表高精度类,用于对比较大或精度比较高的浮点型数据进行操作.因 ...

  6. FFT教你做乘法(FFT傅里叶变换)

    题目来源:https://biancheng.love/contest/41/problem/C/index FFT教你做乘法 题目描述 给定两个8进制正整数A和B(A和B均小于10000位),请利用 ...

  7. [POJ] #1001# Exponentiation : 大数乘法

    一. 题目 Exponentiation Time Limit: 500MS   Memory Limit: 10000K Total Submissions: 156373   Accepted: ...

  8. hdu_1042(模拟大数乘法)

    计算n! #include<cstring> #include<cstdio> using namespace std; ]; int main() { int n; whil ...

  9. hdu1313 Round and Round We Go (大数乘法)

    Problem Description A cyclic number is an integer n digits in length which, when multiplied by any i ...

随机推荐

  1. mvn打包到私服

    mvn打包到私服 1 命令行打包 待定... 2 idea打包 1> 配置 pom.xml <!-- 发布 --><distributionManagement> < ...

  2. SYN攻击源码

    一.linux下源代码实现/* syn flood by wqfhenanxc. * random soruce ip and random sourec port. * use #include & ...

  3. APP_测试流程(测试点)

    1 APP测试基本流程 1.1流程图 1.2测试周期 测试周期可按项目的开发周期来确定测试时间,一般测试时间为两三周(即15个工作日),根据项目情况以及版本质量可适当缩短或延长测试时间. 1.3测试资 ...

  4. win10 64支持承载网络

    在intel官网找到对应型号的网卡驱动. 下载win7版本的,更新驱动.安装完毕之后还要在设备管理里面更新2019 7 30这个版本的驱动. 英特尔® PROSet/无线软件和面向 IT 管理员的驱动 ...

  5. Ubuntu18.04 出现E: Sub-process /usr/bin/dpkg returned an error code (100)

    You might want to reinstall dpkg by doing the following: sudo -i mkdir /tmp/dpkg cd /tmp/dpkg Mind t ...

  6. 牛客 545C 出题人的数组 (贪心)

    出题人有两个数组A,B,请你把两个数组归并起来使得$cost=\sum i c_i$最小. 归并要求原数组的数的顺序在新数组中不改变. 贪心水题 对于一段序列$A_i,A_{i+1},...,A_r$ ...

  7. 百度地图 echarts tooltip属性 经纬度坐标不显示

    中国地图.散点图结合点击后显示当前城市数量 不显示经纬度坐标 echarts.appMap = function (id, opt) { // 实例 var chart = this.init(doc ...

  8. php和java语法区别

    Java和PHP的基本语法基本相同,其实大部分的语言的基本语法也都相同,但是他们还是有一些细微的区别: 1.PHP是一种脚本语言,代码在服务器上执行,而结果以纯文本返回浏览器. 2.PHP能够运行在各 ...

  9. 虚拟机无法启动,提示:无法打开内核功能扩展“com.vmware.kext.vmci”: 无此文件或目录

    打开 系统偏好设置->安全性与隐私->允许打开 即可

  10. [转载]MySQL的存储引擎

    [转载]MySQL的存储引擎 来源:https://www.cnblogs.com/lina1006/archive/2011/04/29/2032894.html 其实这是个只有在MySQL中才存在 ...