[AH2017/HNOI2017]礼物
题解:
水题
化简一波式子会发现就是个二次函数再加上一个常数
而只有常数中的-2sigma(xiyi)是随移动而变化的
所以只要o(1)求出二次函数最大值然后搞出sigma(xiyi)就可以了
这个东西显然只要将一个倒序相乘就可以了
被这个m要乘2坑了一波。。。调了半天才过样例
代码:
- #include <bits/stdc++.h>
- using namespace std;
- #define N 200000
- #define dob complex<double>
- const double pi=acos(-1.0);
- int r[N],sum[N],n,m,k,l;
- dob a[N],b[N];
- void fft(dob *a,int o)
- {
- for (int i=;i<n;i++)
- if (i>r[i]) swap(a[i],a[r[i]]);
- for (int i=;i<n;i*=)
- {
- dob wn(cos(pi/i),sin(pi*o/i)),x,y;
- for (int j=;j<n;j+=(i*))
- {
- dob w(,);
- for (int k=;k<i;k++,w*=wn)
- {
- x=a[j+k]; y=w*a[i+j+k];
- a[j+k]=x+y,a[i+j+k]=x-y;
- }
- }
- }
- }
- void query()
- {
- for (n = ; n <= m; n <<= ) l++;
- for (int i=;i<n;i++) r[i]=(r[i/]/)|((i&)<<(l-));
- fft(a,),fft(b,);
- for (int i=;i<n;i++) a[i]*=b[i];
- fft(a,-);
- for (int i=;i<=m*+;i++) sum[i]=(a[i].real()/n+0.5);
- }
- int main()
- {
- freopen("noip.in","r",stdin);
- freopen("noip.out","w",stdout);
- std::ios::sync_with_stdio(false);
- cin>>m>>k; int x,now=,ans=;
- for (int i=;i<m;i++)
- {
- cin>>x; now+=x; ans+=x*x; a[i]=x;
- }
- for (int i=m-;i>=;i--)
- {
- cin>>x; now-=x; ans+=x*x; b[i]=x;
- }
- int y=-now/m;
- int minn=1e9;
- for (int i=y-;i<=y+;i++)
- minn=min(m*i*i+*i*now,minn);
- ans+=minn;
- int tmp=m; m*=;
- query();
- m=tmp;
- int maxn=sum[m-];
- for (int i=m;i<*m;i++) maxn=max(sum[i]+sum[i-m],maxn);
- ans-=*maxn;
- cout<<ans<<endl;
- return ;
- }
[AH2017/HNOI2017]礼物的更多相关文章
- P3723 [AH2017/HNOI2017]礼物
题目链接:[AH2017/HNOI2017]礼物 题意: 两个环x, y 长度都为n k可取 0 ~ n - 1 c可取任意值 求 ∑ ( x[i] - y[(i + k) % n + 1] ...
- 洛谷 P3723 [AH2017/HNOI2017]礼物 解题报告
P3723 [AH2017/HNOI2017]礼物 题目描述 我的室友最近喜欢上了一个可爱的小女生.马上就要到她的生日了,他决定买一对情侣手环,一个留给自己,一个送给她.每个手环上各有 \(n\) 个 ...
- [Luogu P3723] [AH2017/HNOI2017]礼物 (FFT 卷积)
题面 传送门:洛咕 Solution 调得我头大,我好菜啊 好吧,我们来颓柿子吧: 我们可以只旋转其中一个手环.对于亮度的问题,因为可以在两个串上增加亮度,我们也可以看做是可以为负数的. 所以说,我们 ...
- 笔记-[AH2017/HNOI2017]礼物
笔记-[AH2017/HNOI2017]礼物 [AH2017/HNOI2017]礼物 \[\begin{split} ans_i=&\sum_{j=1}^n(a_j-b_j+i)^2\\ =& ...
- [AH2017/HNOI2017]礼物(FFT)
题目描述 我的室友最近喜欢上了一个可爱的小女生.马上就要到她的生日了,他决定买一对情侣手 环,一个留给自己,一 个送给她.每个手环上各有 n 个装饰物,并且每个装饰物都有一定的亮度.但是在她生日的前一 ...
- 【文文殿下】[AH2017/HNOI2017]礼物
题解 二项式展开,然后暴力FFT就好了.会发现有一个卷积与c无关,我们找一个最小的项就行了. Tips:记得要倍长其中一个数组,防止FFT出锅 代码如下: #include<bits/stdc+ ...
- BZOJ4827:[AH2017/HNOI2017]礼物——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=4827 https://www.luogu.org/problemnew/show/P3723 题面 ...
- Luogu 3723 [AH2017/HNOI2017]礼物
BZOJ 4827 $$\sum_{i = 1}^{n}(x_i - y_i + c)^2 = \sum_{i = 1}^{n}(x_i^2 + y_i^2 + c^2 - 2 * x_iy_i + ...
- 【[AH2017/HNOI2017]礼物】
题目 又是我不会做的题了 看看柿子吧 \[\sum(a_i+c-b_i)^2\] 最小化这个柿子 之所以不写下标是因为我们这个\(\{a\},\{b\}\)可以循环同构 那就开始化吧 \[\sum(a ...
随机推荐
- Java编程思想 学习笔记5
五.初始化与清理 1.用构造器确保初始化 在Java中,通过提供构造器,类的设计者可确保每个对象都会得到初始化.创建对象时,如果其类具有构造器,Java就会在用户有能力操作对象之前自动调用相应的构造 ...
- mysql Mac终端操作
1.启动mysql :brew services start mysql 2.登陆mysql : mysql -u root -p mysql 命令. -u 后面接用户名 root超级管理 ...
- FastReport动态绑定只显示一条数据。
产生这个问题的原因是因为需要把Band绑定DataSource.有两种方法 (1)DataBand data = report1.Report.FindObject("Data1" ...
- IPv4套接字地址结构
一.IPv4套接字地址结构(POSIX定义) (1)长度字段sin_len是为增加对OSI协议的支持而随4.3BSD-Reno添加的:并不是所有的厂家都支持套接字地址结构的长度字段,而且POSIX规范 ...
- Objects源码解析
Objects类解析 JDK7新增Objects类介绍(以下程序以1.8来说明) 简介: JDK7里面新增的Objects类,本人学习HashMap源码偶遇此类,所以研究一下,本类将对象常用的 ...
- Linux 重启网卡失败 Job for network.service failed because the control process exited with error code. See "systemctl status network.service" and "journalctl -xe" for details.
linux下重启网卡使用命令 : service network restart 时报错: [root@slave01 hadoop]# service network restart Startin ...
- 实现一个string类
实现要实现:构造,析构,拷贝构造,赋值的功能 1. 提供构造函数 string(), string(const string & str),string(const char * str), ...
- 关于Linux 虚拟机如何才能ping 通外网
需要虚拟机能够联网.以前都是用桥接模式让虚拟机跟主机通信,这几天查了好多资料,都没有写得很详细,自己捣鼓了很久,把步骤写下来吧. 虚拟机操作步骤: 点击虚拟机的“菜单栏”上的“编辑”,再点击“虚拟网络 ...
- Navicat Premium连接各种数据库
版本信息 Navicat Premium 是一套数据库开发工具,让你从单一应用程序中同时连接 MySQL.MariaDB.SQL Server.Oracle.PostgreSQL 和 SQLite 数 ...
- Node、PHP、Java 和 Go 服务端 I/O 性能PK
http://blog.csdn.net/listen2you/article/details/72935679