先看看。

通常模数常见的有998244353,1004535809,469762049,这几个的原根都是3。
所求的项数还不能超过2的23次方(因为998244353的分解)。

感觉没啥用。

#include <cstdio>
#include <cstring> template <class T>
inline void swap(T &a, T &b)
{
T c;
c = a;
a = b;
b = c;
} const int siz = ; const int P = , G = ; inline int pow(int a, int b)
{
int r = ; while (b)
{
if (b & )
r = 1LL * r * a % P; b >>= , a = 1LL * a * a % P;
} return r;
} inline void calculateNTT(int *s, int n, int f)
{
{
int cnt = ; static int rev[siz]; while (n >> cnt)++cnt; --cnt; memset(rev, , sizeof rev); for (int i = ; i < n; ++i)
{
rev[i] |= rev[i >> ] >> ;
rev[i] |= (i & ) << (cnt - );
} for (int i = ; i < n; ++i)if (i < rev[i])swap(s[i], s[rev[i]]);
} {
for (int i = ; i < n; i <<= )
{
int wn = pow(G, (P - ) / (i * )); if (f == -)wn = pow(wn, P - ); for (int j = ; j < n; j += (i << ))
{
int wk = ; for (int k = ; k < i; ++k, wk = 1LL * wk * wn % P)
{
int x = s[j + k];
int y = 1LL * s[i + j + k] * wk % P; s[j + k] = x + y;
s[i + j + k] = x - y; s[j + k] = (s[j + k] % P + P) % P;
s[i + j + k] = (s[i + j + k] % P + P) % P;
}
}
}
} {
if (f == -)
{
int inv = pow(n, P - ); for (int i = ; i < n; ++i)
s[i] = 1LL * s[i] * inv % P;
}
}
} signed main(void)
{
static char sa[siz];
static char sb[siz]; scanf("%s", sa);
scanf("%s", sb); static int la, a[siz];
static int lb, b[siz]; la = strlen(sa);
lb = strlen(sb); for (int i = ; i < la; ++i)a[i] = sa[la - i - ] - '';
for (int i = ; i < lb; ++i)b[i] = sb[lb - i - ] - ''; int len; for (len = ; len < la || len < lb; len <<= ); calculateNTT(a, len << , +);
calculateNTT(b, len << , +); for (int i = ; i < len << ; ++i)a[i] = 1LL * a[i] * b[i] % P; calculateNTT(a, len << , -); for (int i = ; i < len << ; ++i)a[i + ] += a[i] / , a[i] = a[i] % ; len <<= ; while (!a[len])--len; for (int i = len; ~i; --i)printf("%d", a[i]); puts("");
}

快速傅里叶变换FFT

模板 - 数学 - 快速傅里叶变换/快速数论变换(FFT/NTT)的更多相关文章

  1. 快速傅里叶变换 & 快速数论变换

    快速傅里叶变换 & 快速数论变换 [update 3.29.2017] 前言 2月10日初学,记得那时好像是正月十五放假那一天 当时写了手写版的笔记 过去近50天差不多忘光了,于是复习一下,具 ...

  2. 快速傅里叶变换(Fast-Fourier Transform,FFT)

    数学定义: (详细参考:https://www.baidu.com/link?url=oYAuG2o-pia_U3DlF5n_MJZyE5YKfaVRUHTTDbM1FwM_kDTjGCxKpw_Pb ...

  3. 「算法笔记」快速数论变换(NTT)

    一.简介 前置知识:多项式乘法与 FFT. FFT 涉及大量 double 类型数据操作和 \(\sin,\cos\) 运算,会产生误差.快速数论变换(Number Theoretic Transfo ...

  4. [学习笔记&教程] 信号, 集合, 多项式, 以及各种卷积性变换 (FFT,NTT,FWT,FMT)

    目录 信号, 集合, 多项式, 以及卷积性变换 卷积 卷积性变换 傅里叶变换与信号 引入: 信号分析 变换的基础: 复数 傅里叶变换 离散傅里叶变换 FFT 与多项式 \(n\) 次单位复根 消去引理 ...

  5. 多项式乘法(FFT)模板 && 快速数论变换(NTT)

    具体步骤: 1.补0:在两个多项式最前面补0,得到两个 $2n$ 次多项式,设系数向量分别为 $v_1$ 和 $v_2$. 2.求值:用FFT计算 $f_1 = DFT(v_1)$ 和 $f_2=DF ...

  6. 快速傅里叶变换学习笔记(FFT)

    什么是FFT FFT是用来快速计算两个多项式相乘的一种算法. 如果我们暴力计算两个多项式相乘,复杂度必然是\(O(n^2)\)的,而FFT可以将复杂度降至\(O(nlogn)\) 如何FFT 要学习F ...

  7. 快速傅里叶变换(Fast Fourier Transform, FFT)和短时傅里叶变换(short-time Fourier transform,STFT )【资料整理】【自用】

    1. 官方形象展示FFT:https://www.bilibili.com/video/av19141078/?spm_id_from=333.788.b_636f6d6d656e74.6 2. 讲解 ...

  8. 快速数论变换(NTT)

    刚学完FFT,干脆把NTT也学了算了 (一)预备知识 关于原根,这里说得蛮详细的百度百科 为什么使用原根呢?为什么原根可以替代\(\omega_{n}\)呢?想知道为什么就看here NTT用到的各种 ...

  9. 多项式 之 快速傅里叶变换(FFT)/数论变换(NTT)/常用套路【入门】

    原文链接https://www.cnblogs.com/zhouzhendong/p/Fast-Fourier-Transform.html 多项式 之 快速傅里叶变换(FFT)/数论变换(NTT)/ ...

随机推荐

  1. cocos2d-x 3.0 final 移植 android

    准备工作 你仅仅要依照上一篇的 cocos2d-x 3.0 final 环境搭建 完毕就能够了 1.编辑proj.android\jni\Android.mk,更改内容例如以下 LOCAL_PATH ...

  2. string方法 PadLeft 返回一个新字符串,该字符串通过在此实例中的字符左侧填充指定的 Unicode 字符来达到指定的总长度,从而使这些字符右对齐。 PadRight 右边

  3. 带GPG签名的Git tag

    原文地址http://airk000.github.io/git/2013/09/30/git-tag-with-gpg-key Git tag ###Tag用来做什么? Tag即标签,用以给项目仓储 ...

  4. [leetcode] database解题记录

    175 Combine Two Tables 题目:左连接Person表和Address表. select FirstName,LastName,City,State from Person p le ...

  5. 死去活来的OC NSArray 中文排序 及输出

    目的 1.NSArray 能够支持中文排序 2.NSLog 能够直接输出 NSArray 内的中文(事实上 java 直接打印数组也不能显示内容哈) 又是死去活来的搞了1个小时,分类实现.废话少说,上 ...

  6. 【 D3.js 进阶系列 — 1.2 】 读取 CSV 文件时乱码的解决方法

    在 D3 中使用 d3.csv 读取 CSV 文件时,有时会出现乱码问题. 怎么解决呢? 1. 乱码问题 使用 d3.csv 读取 xxx.csv 文件时.假设 xxx.csv 文件使用的是 UTF- ...

  7. C/C++语言中的位运算

    在计算机程序中,数据的位是可以操作的最小数据单位,理论上可以用“位运算”来完成所有的运算和操作. 一般的位操作是用来控制硬件的,或者做数据变换使用,但是,灵活的位操作可以有效地提高程序运行的效率.C语 ...

  8. object-c iOS 教程 git for mac

    本文转载至 http://blog.csdn.net/u011728347/article/details/10035191   http://rypress.com/tutorials/object ...

  9. 将线上服务器生成的日志信息实时导入kafka,采用agent和collector分层传输,app的数据通过thrift传给agent,agent通过avro sink将数据发给collector,collector将数据汇集后,发送给kafka

    记flume部署过程中遇到的问题以及解决方法(持续更新) - CSDN博客 https://blog.csdn.net/lijinqi1987/article/details/77449889 现将调 ...

  10. sqlldr trailing nullcols

    由于要导入到tmp_content表的一些列(列:要导入的源文件txt or csv文件)为空,也,按理讲我当时另存为(在windows处理)csv,以,分隔.就是这个列没有内容,也该显示, ,之类的 ...