hihocoder #1388 : Periodic Signal NTT&FFT
传送门:hihocoder #1388 : Periodic Signal
先来几个大牛传送门: (模板) NTT long long 版
解法一:因为我们知道FFT会精度不够,所以坚持用NTT,但是模数不够大,然后就一直GG,看来我们的搜索姿势也有问题,居然没有搜到上面大神的板子,真的是GG
http://www.cnblogs.com/WABoss/p/5903927.html
- /**************************************************************
- Problem:
- User: youmi
- Language: C++
- Result: Accepted
- Time:
- Memory:
- ****************************************************************/
- //#pragma comment(linker, "/STACK:1024000000,1024000000")
- //#include<bits/stdc++.h>
- #include <iostream>
- #include <cstdio>
- #include <cstring>
- #include <algorithm>
- #include <map>
- #include <stack>
- #include <set>
- #include <sstream>
- #include <cmath>
- #include <queue>
- #include <deque>
- #include <string>
- #include <vector>
- #define zeros(a) memset(a,0,sizeof(a))
- #define ones(a) memset(a,-1,sizeof(a))
- #define sc(a) scanf("%d",&a)
- #define sc2(a,b) scanf("%d%d",&a,&b)
- #define sc3(a,b,c) scanf("%d%d%d",&a,&b,&c)
- #define scs(a) scanf("%s",a)
- #define sclld(a) scanf("%I64d",&a)
- #define pt(a) printf("%d\n",a)
- #define ptlld(a) printf("%I64d\n",a)
- #define rep(i,from,to) for(int i=from;i<=to;i++)
- #define irep(i,to,from) for(int i=to;i>=from;i--)
- #define Max(a,b) ((a)>(b)?(a):(b))
- #define Min(a,b) ((a)<(b)?(a):(b))
- #define lson (step<<1)
- #define rson (lson+1)
- #define eps 1e-6
- #define oo 0x3fffffff
- #define TEST cout<<"*************************"<<endl
- const double pi=*atan(1.0);
- using namespace std;
- typedef long long ll;
- int n;
- const ll P = 50000000001507329LL; //190734863287 * 2 ^ 18 + 1
- //const ll P = 1004535809LL; //479 * 2 ^ 21 + 1
- //const ll P = 1004535809; // 119 * 2 ^ 23 + 1
- const int N = << ;
- const int G = ;
- int len;
- ll A[N],B[N];
- long long a[N],b[N],wn[];
- ll mul(ll x, ll y) {
- return (x * y - (ll)(x / (long double)P * y + 1e-) * P + P) % P;
- }
- ll qpow(ll x, ll k, ll p) {
- ll ret = ;
- while(k) {
- if(k & ) ret = mul(ret, x);
- k >>= ;
- x = mul(x, x);
- }
- return ret;
- }
- void getwn()
- {
- for(int i = ; i <= ; ++i)
- {
- int t = << i;
- wn[i] = qpow(G, (P - ) / t, P);
- }
- }
- void change(ll *y, int len)
- {
- for(int i = , j = len / ; i < len - ; ++i)
- {
- if(i < j) swap(y[i], y[j]);
- int k = len / ;
- while(j >= k)
- {
- j -= k;
- k /= ;
- }
- j += k;
- }
- }
- void NTT(ll *y, int len, int on)
- {
- change(y, 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 = y[k];
- ll t = mul(y[k+h/], w);
- y[k] = u + t;
- if(y[k] >= P) y[k] -= P;
- y[k+h/] = u - t + P;
- if(y[k+h/] >= P) y[k+h/] -= P;
- w = mul(w, wn[id]);
- }
- }
- }
- if(on == -)
- {
- for(int i = ; i < len / ; ++i) swap(y[i], y[len-i]);
- ll inv = qpow(len, P - , P);
- for(int i = ; i < len; ++i)
- y[i] = mul(y[i], inv);
- }
- }
- void work()///卷积,点乘,插值
- {
- NTT(a,len,);
- NTT(b,len,);
- for(int i=;i<len;i++)
- a[i]=mul(a[i],b[i]);
- NTT(a,len,-);
- }
- ll solve()
- {
- zeros(a);
- zeros(b);
- rep(i,,n-)
- a[i]=A[i];
- rep(i,,n-)
- b[i]=B[i];
- reverse(b,b+n);
- work();
- ll ans=;
- rep(i,,n-)
- a[i]+=a[i+n];
- rep(i,,n-)
- ans=max(ans,*a[i]);
- return ans;
- }
- int main()
- {
- #ifndef ONLINE_JUDGE
- freopen("in.txt","r",stdin);
- #endif
- int T_T;
- scanf("%d",&T_T);
- getwn();
- for(int kase=;kase<=T_T;kase++)
- {
- sc(n);
- len=;
- while(len<=*n)
- len<<=;
- rep(i,,n-)
- cin>>A[i];
- rep(i,,n-)
- cin>>B[i];
- ll temp=;
- rep(i,,n-)
- temp+=A[i]*A[i];
- rep(i,,n-)
- temp+=B[i]*B[i];
- ll ans=solve();
- ans=temp-ans;
- cout<<(ans)<<endl;
- }
- }
解法二:这个解法确实很漂亮,比赛的时候一直徘徊找一个更大的 模数,然后就GG了,http://www.cnblogs.com/smartweed/p/5903838.html
解法三:其实这种解法我们也尝试了,队友说NTT搞了那么久,说明暴力应该可以,不过最后只剩几分钟来不及找到合适的循环次数,http://www.cnblogs.com/cshg/p/5905398.html
hihocoder #1388 : Periodic Signal NTT&FFT的更多相关文章
- hihoCoder 1388 Periodic Signal(FFT)
[题目链接] http://hihocoder.com/problemset/problem/1388 [题目大意] 给出A数列和B数列,求下图式子: [题解] 我们将多项式拆开,我们可以得到固定项A ...
- hihocoder #1388 : Periodic Signal fft
题目链接: https://hihocoder.com/problemset/problem/1388 Periodic Signal 时间限制:5000ms内存限制:256MB 问题描述 Profe ...
- hihocode #1388 : Periodic Signal NTT
#1388 : Periodic Signal 描述 Profess X is an expert in signal processing. He has a device which can ...
- hihoCoder #1388 : Periodic Signal ( 2016 acm 北京网络赛 F题)
时间限制:5000ms 单点时限:5000ms 内存限制:256MB 描述 Profess X is an expert in signal processing. He has a device w ...
- hihoCoder #1388 : Periodic Signal
NTT (long long 版) #include <algorithm> #include <cstring> #include <string.h> #inc ...
- 【hihocoder#1388】Periodic Signal NTT
题目链接:http://hihocoder.com/problemset/problem/1388?sid=974337 题目大意:找出一个$k$,使得$\sum_{i=0}^{n-1}(A_{i}- ...
- hihocoder 1388 &&2016 ACM/ICPC Asia Regional Beijing Online Periodic Signal
#1388 : Periodic Signal 时间限制:5000ms 单点时限:5000ms 内存限制:256MB 描述 Profess X is an expert in signal proce ...
- hihocoder 1388 fft循环矩阵
#1388 : Periodic Signal 时间限制:5000ms 单点时限:5000ms 内存限制:256MB 描述 Profess X is an expert in signal proce ...
- NTT&FFT(快速?变换)
NTT&FFT 预先知识:无 我觉得我们可以从NTT/FFT讲起? 两个其实本质相同,都是求 多项式乘积 的算法 FFT \((x,y)\)指复数,我们可以不用管它 首先我们构造单位根\(\o ...
随机推荐
- NativeScript - JS 构建跨平台的原生 APP
使用 NativeScript,你可以用现有的 JavaScript 和 CSS 技术来编写 iOS.Android 和 Windows Phone 原生移动应用程序.由原生平台的呈现引擎呈现界面而不 ...
- MySQL索引类型 btree索引和hash索引的区别
来源一 Hash 索引结构的特殊性,其检索效率非常高,索引的检索可以一次定位,不像B-Tree 索引需要从根节点到枝节点,最后才能访问到页节点这样多次的IO访问,所以 Hash 索引的查询效率要远高于 ...
- 未找到与约束ContractName Microsoft.VisualStudio.Text.ITextDocumentFactoryService... 匹配的导出 VS2012报错
刚安装完VS2012,打开VS2012新建项目,但是并没有像之前那样顺利的创建页面,而是弹出了一个错误窗口. 我的系统是win7旗舰版 64位 ,同时安装了VS2010和VS2012.然后我又试了一下 ...
- Egret白鹭H5小游戏开发入门(三)
前言: 在上一篇文章中着重介绍了H5小游戏开发的起步阶段,如Wing面板的使用,素材的处理,类的说明等等,那么今天主要是涉及到场景的创建,loading的修改等等的代码编写. 对于这一节,我在讲解的过 ...
- FM四舍五入_从小数点最后一位进位
原贴地址:http://jiahongguang12.blog.163.com/blog/static/334665720071060551591/ 输入参数12.5445,因此FM从小数点最后一位进 ...
- 无线安全审计工具 Fern WiFi Cracker
使用这款工具前最好自定义一个MAC地址,以便隐藏我们的真实MAC地址信息. 由于Fern WiFi Cracker是图形界面的,不需要敲命令,所以操作起来比Aircrack-ng简单了许多. 首先选择 ...
- Android Handler机制(一)---Message源码分析
Message: 定义: public final class Message implements Parcelable Message类是个final类,就是说不能被继承,同时Message类实现 ...
- jquery非空验证功能
<script type="text/javascript"> $(function(){ /************* ...
- 找window的三种方法
LoginViewController * loginVC = [[LoginViewController alloc]init]; 找window的三种方式 1.// UIWindow * wind ...
- 关于Linux与windows传递文件乱码问题
linux下一般是采用utf-8的编码,而我们在windows上编辑文件时是gb2312的编码.所以导致中文编码会乱码.要更正这个问题实际上很简单只要把文件转换成utf-8编码格式然后再导入就ok啦. ...