关于傅里叶变换NTT(FNT)的周边
NTT:快速数论变化,对于FFT精度减少的情况,NTT可以避免但是会慢一点,毕竟是数论有Mod,和快速米
引用:http://blog.csdn.net/zz_1215/article/details/40430041
周边介绍。
利用原根,在ZP整数域(后悔没学好《信息安全数学基础》
然后对于一个整数域中的值分别对应一个数,具体看下这类数学书,用来替代单位根
对于一个P(素数)
比较快的一种方法找原根:http://blog.csdn.net/zhang20072844/article/details/11541133 (ORZ
大概是对于P的一个大于1的因子满足G^因子%P==1,那么就不是原根,原根很小。
其他跟FFT没区别。
其实傅里叶变化关键还是能够化成卷积的形式(这里只是处理普通和答案要求Mod的时候)
要求答案的逆,和除法,要看Picks的博客:
NTT:
#include<iostream>
#include<string.h>
#include<stdio.h>
#include<math.h> using namespace std;
typedef long long ll;
const int N=<<;
const int P=;
const int G=;
const int NUM=;
ll wn[NUM],a[N],b[N];
char A[N],B[N]; ll Pow(ll a,ll b,ll m)
{
ll ans=;
a%=m;
while (b)
{
if (b&) ans=ans*a%m;
a=a*a%m;
b/=;
}
return ans;
} void Getwn()
{
for (int i=;i<NUM;i++)
{
int t=<<i;
wn[i]=Pow(G,(P-)/t,P);
}
} void Rader(ll a[],int len)
{
int j=len>>;
for (int i=;i<len-;i++)
{
if (i<j) swap(a[i],a[j]);
int k=len>>;
while (j>=k)
{
j-=k;
k>>=;
}
if (j<k) j+=k;
}
} void NTT(ll a[],int len,int on)
{
Rader(a,len);
int id=;
for (int h=;h<=len;h<<=)
{
id++;
for (int j=;j<len;j+=h)
{
ll w=;
for (int k=j;k<j+h/;k++)
{
ll u=a[k]%P;
ll t=w*(a[k+h/]%P)%P;
a[k]=(u+t)%P;
a[k+h/]=((u-t)%P+P)%P;
w=w*wn[id]%P;
}
}
} if (on==-)
{
for (int i=;i<len/;i++)
swap(a[i],a[len-i]);
ll inv=Pow(len,P-,P);
for (int i=;i<len;i++)
a[i]=a[i]%P*inv%P;
}
}
void Conv(ll a[],ll b[],int n)
{
NTT(a,n,);
NTT(b,n,);
for (int i=;i<n;i++)
a[i]=a[i]*b[i]%P;
NTT(a,n,-);
} int pan(char s[],char ss[])
{
int len=strlen(s);
len--;
while (s[len]==''&&len>=) len--;
if (len<) return ; len=strlen(ss);
len--;
while (ss[len]==''&&len>=) len--;
if (len<) return ;
return ;
}
int main()
{
Getwn();
while (scanf("%s%s",A,B)!=EOF)
{
if (pan(A,B))
{
puts("");
continue;
}
int len=;
int lenA=strlen(A);
int lenB=strlen(B);
while (len<=*lenA||len<=*lenB) len<<=;
for (int i=;i<lenA;i++)
A[len--i]=A[lenA--i];
for (int i=;i<len-lenA;i++) A[i]=''; for (int i=;i<lenB;i++)
B[len--i]=B[lenB--i];
for (int i=;i<len-lenB;i++) B[i]='';
for (int i=;i<len;i++) a[len--i]=A[i]-'';
for (int i=;i<len;i++) b[len--i]=B[i]-'';
Conv(a,b,len); int t=;
for (int i=;i<len;i++)
{
a[i]+=t;
if (a[i]>)
{
t=a[i]/;
a[i]%=;
}
else t=;
}
len--;
while (a[len]==) len--;
for (int i=len;i>=;i--) printf("%d",a[i]);
puts("");
}
return ;
}
关于傅里叶变换NTT(FNT)的周边的更多相关文章
- dynamic routing between captual
对于人脑 决策树形式 对于CNN 层级与层级间的传递 人在识别物体的时候会进行坐标框架的设置 CNN无法识别,只能通过大量训练 胶囊 :一个神经元集合,有一个活动的向量,来表示物体的各类信息,向量的长 ...
- FFT的应用
FFT的应用 --讲稿 概述 FFT的模板很简单,大家都会背,于是出题的空间就在于建模了.FFT的题目难在建模,往往需要将问题抽象出来,经过一系列转化后得到乘积式的和,再赋予式子各个项的系数一定的意义 ...
- 多项式 之 快速傅里叶变换(FFT)/数论变换(NTT)/常用套路【入门】
原文链接https://www.cnblogs.com/zhouzhendong/p/Fast-Fourier-Transform.html 多项式 之 快速傅里叶变换(FFT)/数论变换(NTT)/ ...
- 快速傅里叶变换FFT& 数论变换NTT
相关知识 时间域上的函数f(t)经过傅里叶变换(Fourier Transform)变成频率域上的F(w),也就是用一些不同频率正弦曲线的加 权叠加得到时间域上的信号. \[ F(\omega)=\m ...
- 快速傅里叶变换FFT / NTT
目录 FFT 系数表示法 点值表示法 复数 DFT(离散傅里叶变换) 单位根的性质 FFT(快速傅里叶变换) IFFT(快速傅里叶逆变换) NTT 阶 原根 扩展知识 FFT 参考blog: 十分简明 ...
- 从傅里叶变换(FFT)到数论变换(NTT)
FFT可以用来计算多项式乘法,但是复数的运算中含有大量的浮点数,精度较低.对于只有整数参与运算的多项式,有时,\(\text{NTT(Number-Theoretic Transform)}\)会是更 ...
- Algorithm: 多项式乘法 Polynomial Multiplication: 快速傅里叶变换 FFT / 快速数论变换 NTT
Intro: 本篇博客将会从朴素乘法讲起,经过分治乘法,到达FFT和NTT 旨在能够让读者(也让自己)充分理解其思想 模板题入口:洛谷 P3803 [模板]多项式乘法(FFT) 朴素乘法 约定:两个多 ...
- 再探快速傅里叶变换(FFT)学习笔记(其三)(循环卷积的Bluestein算法+分治FFT+FFT的优化+任意模数NTT)
再探快速傅里叶变换(FFT)学习笔记(其三)(循环卷积的Bluestein算法+分治FFT+FFT的优化+任意模数NTT) 目录 再探快速傅里叶变换(FFT)学习笔记(其三)(循环卷积的Blueste ...
- 快速傅里叶变换(FFT)学习笔记(其二)(NTT)
再探快速傅里叶变换(FFT)学习笔记(其二)(NTT) 目录 再探快速傅里叶变换(FFT)学习笔记(其二)(NTT) 写在前面 一些约定 前置知识 同余类和剩余系 欧拉定理 阶 原根 求原根 NTT ...
随机推荐
- Ubuntu12.04安装Chrome浏览器,并添加到左侧的启动栏
在google官网下载google chrome deb包,有32位和64位之分: 怎么判断系统是32位还是64位的,可以用以下代码: ; int *p = &a; printf(" ...
- Bootsrtap 面包屑导航(Breadcrums)
Bootstrap面包屑导航是一种基于网站层次信息显示的方式.以博客为例,面包屑导航可以显示发布日期,类别或标签,它们表示当前页面在导航层次结构内的位置. Bootstrap面包屑导航其实是一个简单的 ...
- perl学习之:localtime
Perl中localtime()函数以及sprintf (2011-4-25 19:39)localtime函数 localtime函数,根据它所在的上下文,可以用两种完全不同的方法来运行.在标量上下 ...
- Linux中的定时任务简单操作实例
今天,我怀着一颗感恩的心,写了一个小小的定时任务,细想还是写个简单的例子吧,希望能帮到你! 首先我在/usr/local/文件夹下创建了一个文件,hah.sh文件 在hah.sh里面编写shell脚本 ...
- shell相关指令介绍$*和$#以及$?和if [[ ! -z $1 ]]
$#,脚本运行时后跟的参数个数 #! /bin/bash case "$#" in 0) printf "Enter a number: " read n=$R ...
- Ubuntu 清理卸载残留文件
dpkg -l |grep ^rc|awk '{print $2}' |sudo xargs dpkg -P
- 00031_ArrayList集合中常用的方法
1.ArrayList集合提供的一些常用方法 import java.util.ArrayList; public class ArrayListDemo01 { public static void ...
- 【LeetCode】Jewels and Stones(宝石与石头)
这道题是LeetCode里的第771道题. 题目要求: 给定字符串J 代表石头中宝石的类型,和字符串 S代表你拥有的石头. S 中每个字符代表了一种你拥有的石头的类型,你想知道你拥有的石头中有多少是宝 ...
- 有关C语言指针访问问题
C语言指针访问问题今天有了一些理解. char *p; char *q; char k[10000]; 我之前一直以为他们两个一样用,因为之前看到说k也是一个地址,我忽略了后面的一句话,k是连续的一段 ...
- 九度oj 题目1086:最小花费
题目描述: 在某条线路上有N个火车站,有三种距离的路程,L1,L2,L3,对应的价格为C1,C2,C3.其对应关系如下: 距离s 票价 0<S<=L1 ...