记得FFT要开大数组!!开到快MLE的那种!!我这个就是例子TAT,5e5都RE了

在这题上花的时间太多了,还是FFT不太熟练。

首先看70分的n方做法:从0下标开始存,先n--,把a数组倍增,然后枚举a数组的起点st(相当于环上a的st和b的0相匹配),设x为增量

\[\sum_{i=0}^{n}(a[i+s]+x-b[i])^2
\]

\[=\sum_{i=0}^{n}(a[i+s]-b[i])^2+x^2-2*x*(a[i+s]-b[i])
\]

\[=\sum_{i=0}^{n}(a[i+s]-b[i])^2+n*x^2-x*2*\sum_{i=0}^{n}(a[i+s]-b[i])
\]

\[a=n,b=2*\sum_{i=0}^{n}(a[i+s]-b[i]),c=\sum_{i=0}^{n}(a[i+s]-b[i])^2
\]

显然这是一个开口向上的二次函数,所以可以用二次函数求顶点公式求。(注意!不能直接求y,因为x是整数,但是求顶点公式求出来的不一定是,我简单粗暴的把floor和ceil取了个min)

这个暴力在考场上性价比非常高,大概20min就能得70分;

然后正解,观察上面式子,发现设:

\[sa=\sum_{i=0}^{n}a[i],saf=\sum_{i=0}^{n}a[i]*a[i]
\]

\[sb=\sum_{i=0}^{n}b[i],sbf=\sum_{i=0}^{n}b[i]*b[i]
\]

那么:

\[a=n,b=2*(sa-sb),c=saf+sab-2*\sum_{i=0}^{n}(a[i+s]*b[i])
\]

现在只有设\( c[i]=\sum_{i=0}^{n}(a[i+s]*b[i]) \),不是常数,考虑怎么把它化成卷积形式然后FFT预处理。

设:

\[z[i]=\sum_{j=0}^{n-i}x[j]y[i+j],f[i]=\sum_{j=0}^{n-i}y[j]x[i+j]
\]

\[c[i]=z[i]+f[n-i+1]
\]

设nx为x数组反过来,设ny为y数组反过来,然后随便推一推就会发现z和f变成这样:

\[z[n-i]=\sum_{j=0}^{n-i}x[i-j]ny[j],f[n-i]=\sum_{j=0}^{n-i}y[i-j]nx[j]
\]

然后FFT预处理即可;

#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;
const int N=1000005;
int re[N],lm,bt;
long long n,m,a[N],b[N],sa,saf,sb,sbf,c[N],x1,x2,ans=1e18;
struct cd
{
double r,i;
cd(double R=0,double I=0)
{
r=R,i=I;
}
cd operator + (const cd &a) const
{
return cd(r+a.r,i+a.i);
}
cd operator - (const cd &a) const
{
return cd(r-a.r,i-a.i);
}
cd operator * (const cd &a) const
{
return cd(r*a.r-i*a.i,a.r*i+a.i*r);
}
}x[N],y[N],nx[N],ny[N];
int read()
{
int r=0,f=1;
char p=getchar();
while(p>'9'||p<'0')
{
if(p=='-')
f=-1;
p=getchar();
}
while(p>='0'&&p<='9')
{
r=r*10+p-48;
p=getchar();
}
return r*f;
}
void dft(cd a[],int f)
{
for(int i=0;i<lm;i++)
if(i<re[i])
swap(a[i],a[re[i]]);
for(int i=1;i<lm;i<<=1)
{
cd wi=cd(cos(M_PI/i),f*sin(M_PI/i));
for(int k=0;k<lm;k+=(i<<1))
{
cd w=cd(1,0),x,y;
for(int j=0;j<i;j++)
{
x=a[k+j];
y=a[i+j+k]*w;
a[k+j]=x+y;
a[i+j+k]=x-y;
w=w*wi;
}
}
}
if(f==-1)
{
for(int i=0;i<lm;i++)
a[i].r/=lm;
}
}
void fft(cd a[],cd b[])
{
dft(a,1);
dft(b,1);
for(int i=0;i<lm;i++)
a[i]=a[i]*b[i];
dft(a,-1);
}
int main()
{
n=read()-1,m=read();
for(int i=0;i<=n;i++)
a[i]=read(),sa+=a[i],saf+=a[i]*a[i];
for(int i=0;i<=n;i++)
b[i]=read(),sb+=b[i],sbf+=b[i]*b[i];
for(int i=0;i<=n;i++)
{
x[i].r=b[i],y[i].r=a[i];
nx[i].r=b[n-i],ny[i].r=a[n-i];
}
for(lm=1,bt=0;lm<=2*n;bt++,lm<<=1);
for(int i=0;i<lm;i++)
re[i]=(re[i>>1]>>1)|((i&1)<<(bt-1));
fft(x,ny);
fft(y,nx);
for(int i=0;i<=n;i++)
c[i]=(int)(1.0*(x[n-i].r+y[i-1].r)+0.5);//,cout<<c[i]<<endl;
x1=0-floor(1.0*(sa-sb)/(n+1)),x2=0-ceil(1.0*(sa-sb)/(n+1));//cout<<x1<<" "<<x2<<endl;
for(int i=0;i<=(n+1);i++)
{
ans=min(ans,min((n+1)*x1*x1+2*(sa-sb)*x1+saf+sbf-2*c[i],(n+1)*x2*x2+2*(sa-sb)*x2+saf+sbf-2*c[i]));
// cout<<sa<<" "<<sb<<" "<<saf<<" "<<sbf<<" "<<x1<<" "<<x2<<" "<<c[i]<<" "<<ans<<endl;
}
printf("%lld\n",ans);
return 0;
}

bzoj 4827: [Hnoi2017]礼物【FFT】的更多相关文章

  1. bzoj 4827: [Hnoi2017]礼物 [fft]

    4827: [Hnoi2017]礼物 题意:略 以前做的了 化一化式子就是一个卷积和一些常数项 我记着确定调整值还要求一下导... #include <iostream> #include ...

  2. bzoj 4827 [Hnoi2017]礼物——FFT

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4827 式子就是 \sum_{i=0}^{n-1}(a[ i ] - b[ i+k ] + c ...

  3. bzoj 4827 [Hnoi2017] 礼物 —— FFT

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4827 首先,旋转对应,可以把 b 序列扩展成2倍,则 a 序列对应到的还是一段区间: 再把 ...

  4. BZOJ 4827 [Hnoi2017]礼物 ——FFT

    题目上要求一个循环卷积的最小值,直接破环成链然后FFT就可以了. 然后考虑计算的式子,可以分成两个部分分开计算. 前半部分FFT,后半部分扫一遍. #include <map> #incl ...

  5. bzoj 4827: [HNOI2017]礼物 (FFT)

    一道FFT 然而据说暴力可以水70分 然而我省选的时候看到了直接吓傻了  连暴力都没打 太弱了啊QAQ emmmm 详细的拆开就看其他题解吧233 最后那一步卷积其实我一直没明白 后来画画图终于懂了 ...

  6. 【刷题】BZOJ 4827 [Hnoi2017]礼物

    Description 我的室友最近喜欢上了一个可爱的小女生.马上就要到她的生日了,他决定买一对情侣手 环,一个留给自己,一个送给她.每个手环上各有 n 个装饰物,并且每个装饰物都有一定的亮度.但是在 ...

  7. BZOJ 4827: [Hnoi2017]礼物 FFT_多项式_卷积

    题解稍后在笔记本中更新 Code: #include <bits/stdc++.h> #define setIO(s) freopen(s".in","r&q ...

  8. BZOJ:4827: [Hnoi2017]礼物

    [问题描述] 我的室友最近喜欢上了一个可爱的小女生.马上就要到她的生日了,他决定买一对情侣手 环,一个留给自己,一个送给她.每个手环上各有 n 个装饰物,并且每个装饰物都有一定的亮度. 但是在她生日的 ...

  9. 4827: [Hnoi2017]礼物

    4827: [Hnoi2017]礼物 链接 分析: 求最小的$\sum_{i=1}^{n}(x_i-y_i)^2$ 设旋转了j位,每一位加上了c. $\sum\limits_{i=1}^{n}(x_{ ...

随机推荐

  1. Spring实战Day1

    为什么要学习使用Spring ------为了全方面简化Java开发 如何简化开发呢? 1.基于POJO[简单老式Java对象(Plain Old Java object)]的轻量级和最小侵入性编程, ...

  2. Java日志框架-Logback手册中文版以及官方配置文档教程

    Logback手册中文版:(链接: https://pan.baidu.com/s/1bpMyasR 密码: 6u5c),虽然版本有点旧,但是大体意思差不多,先用中文版了解个大概,然后一切最新的配置以 ...

  3. eclipse设置每次提交代码忽略target、.settings、.svn、.project文件

  4. CommonTabLayout+ViewPager快速完成APP首页搭建

    款APP开始的时候往往少不了多页面的切换,这就涉及到viewpager的使用,以前往往用Google自带的效果去实现,比较麻烦不说,后面做出来的效果还不如人意. 下面就利用CommonTabLayou ...

  5. 以Java属性文件的格式创建Hibernate的配置文件和DTD特殊符号作用

    演示样例代码 hibernate.dialect=org.hibernate.dialect.MySQLDialect hibernate.connection.driver_class=com.my ...

  6. HLJU 1220: AC100天 (枚举)

    1220: AC100天 Time Limit: 1 Sec  Memory Limit: 128 MB Submit: 89  Solved: 12 [id=1220">Submit ...

  7. sparse-PCA(稀疏主成分分析)是什么?

    不多说,直接上干货! 复杂降维技术有spare-PCA和sparse coding. 最近在科研需要,感谢下面的博主. Sparse PCA 稀疏主成分分析

  8. Android碎纸机效果

    1.总体思想 活用padding和margin 2.实现过程 public class PopupShredderView extends FrameLayout{ public PopupShred ...

  9. 下面forward和redirect的描述,正确的是(ABCD)

    A:forward是服务器将控制权转交给内部服务器对象,由新的对象来全权负责响应用户的请求 B:执行forward时,浏览器不知道服务器所发送的内容从那里来,浏览器地址栏中还是原来的地址 C:执行re ...

  10. 为Windows Live Writer添加Code插件

    1.插件效果展示 1: void CDemoDlg::OnBnClickedNmdlg() 2: { 3: CNonModeDlg *pDlg = new CNonModeDlg();// 创建一个C ...