题目链接

题目为某次雅礼集训...


对于\(\max\{a-A_i,\ A_i-a,\ b-B_i,\ B_i-b\}\),令\(x_1=\frac{a+b}{2},\ y_1=\frac{a-b}{2},\ x_2=\frac{A_i+B_i}{2},\ y_2=\frac{A_i-B_i}{2}\),那么\(\max\)就可以写成\(\max\{x_1-x_2+y_1-y_2,\ -(x_1-x_2)-(y_1-y_2),\ x_1-x_2-(y_1-y_2),\ -(x_1-x_2)+y_1-y_2\}\)。

注意到两项的正负都取到了,我们就可以写成\(\pm(x_1-x_2)\pm(y_1-y_2)=|x_1-x_2|+|y_1-y_2|\)。两项是独立的了,我们可以分别算。

\(x_2,y_2\)是确定的,现在要确定一个\(x_1,y_1\),使得\(\sum|x_1-x_{2,i}|+\sum|y_1-y_{2,i}|\)最小(确定出\(x_1,y_1\)我们显然可以确定出\(a,b\))。

这个问题...考虑一个问题:数轴上有些点,选择一个位置使得它到所有点的距离和最小,就是\(\min\{\sum|p-x_i|\}\),我们取中位数就可以了。

对于\(\sum|x_1-x_{2,i}|\),同样取\(x_2\)的中位数就可以了。区间中位数可以用主席树求。

懒得离散化了...


//6026ms	137.211MiB
#include <cmath>
#include <cstdio>
#include <cctype>
#include <algorithm>
//#define gc() getchar()
#define MAXIN 500000
#define gc() (SS==TT&&(TT=(SS=IN)+fread(IN,1,MAXIN,stdin),SS==TT)?EOF:*SS++)
typedef long long LL;
const int N=1e5+5; int A[N],B[N],root1[N],root2[N];
char IN[MAXIN],*SS=IN,*TT=IN;
struct Segment_Tree
{
#define ls son[x][0]
#define rs son[x][1]
#define S N*35
int tot,sz[S],son[S][2];
LL ans,sum[S];
#undef S
void Insert(int &x,int y,int l,int r,int p)
{
sz[x=++tot]=sz[y]+1, sum[x]=sum[y]+p;
if(l==r) return;
int m=(LL)l+r>>1;//LL!
p<=m?(rs=son[y][1],Insert(ls,son[y][0],l,m,p)):(ls=son[y][0],Insert(rs,son[y][1],m+1,r,p));
}
int Query(int x,int y,int l,int r,int k)//x-y
{
if(l==r) return l;
int m=(LL)l+r>>1,mid,t=sz[ls]-sz[son[y][0]];
if(t>=k)
mid=Query(ls,son[y][0],l,m,k), ans+=sum[rs]-sum[son[y][1]]-1ll*mid*(sz[rs]-sz[son[y][1]]);
else
mid=Query(rs,son[y][1],m+1,r,k-t), ans+=1ll*mid*(sz[ls]-sz[son[y][0]])-(sum[ls]-sum[son[y][0]]);
return mid;
}
}T1,T2; inline int read()
{
int now=0,f=1;register char c=gc();
for(;!isdigit(c);c=='-'&&(f=-1),c=gc());
for(;isdigit(c);now=now*10+c-48,c=gc());
return now*f;
} int main()
{
// freopen("spy.in","r",stdin);
// freopen("spy.out","w",stdout); #define S1 L1,R1
#define S2 L2,R2
int n=read(),q=read(),mnA=1e9,mxA=-1e9,mnB=1e9,mxB=-1e9;
for(int i=1; i<=n; ++i) A[i]=read(),mnA=std::min(mnA,A[i]),mxA=std::max(mxA,A[i]);
for(int i=1; i<=n; ++i) B[i]=read(),mnB=std::min(mnB,B[i]),mxB=std::max(mxB,B[i]);
int L1=mnA+mnB,R1=mxA+mxB,L2=mnA-mxB,R2=mxA-mnB;
for(int i=1; i<=n; ++i) T1.Insert(root1[i],root1[i-1],S1,A[i]+B[i]), T2.Insert(root2[i],root2[i-1],S2,A[i]-B[i]);
for(; q--; )
{
int l=read(),r=read(),p=r-l+2>>1;
T1.ans=0, T2.ans=0, T1.Query(root1[r],root1[l-1],S1,p), T2.Query(root2[r],root2[l-1],S2,p);
printf("%.2lf\n",(T1.ans+T2.ans)*0.5);
} return 0;
}

最新文章

  1. PostgreSQL 与 MySQL 相比,优势何在?
  2. Serializable
  3. fedora 安装vmwear
  4. 【python2.7】raw_input()和input()区别及用法
  5. 高德地图 JavaScript API 开发系列教程(二)
  6. 【转】cocos2d-x获取系统时间&mdash;&mdash;2013-08-25 10
  7. 使用Transaction访问数据库(C#,TransactionScope,.NET 2.0)
  8. S3C6410 纯粹的裸机启动,自己写的SD BOOT启动
  9. keystone policy.json 的学习总结
  10. Java - extends
  11. Django 框架基础
  12. iOS启动速度优化
  13. java、python与留下迷点的php hash collision
  14. OJ#1002 又是a+b
  15. 使用sqoop从mysql导入数据到hive
  16. 阿里云服务器配置nginx和PHP
  17. Thumbnailator java图片压缩,加水印,批量生成缩略图
  18. Ruby for Sketchup 贪吃蛇演示源码(naive_snake)
  19. Qt学习过程中遇到的问题
  20. Dubbo (开源分布式服务框架)

热门文章

  1. poj1185 状态压缩经典题
  2. 第八周学习总结-C#、C++
  3. C++ Primer 笔记——函数
  4. BZOJ 2818 Gcd(欧拉函数+质数筛选)
  5. C#递归拷贝文件删除文件
  6. asp.net core ioc 依赖注入
  7. SVG 图像入门教程
  8. 一脸懵逼加从入门到绝望学习hadoop之 org.apache.hadoop.ipc.RemoteException(org.apache.hadoop.security.AccessControlException): Permission denied: user=Administrator, access=WRITE, inode=&quot;/&quot;:root:supergroup:drwxr-xr报错
  9. Spring MVC基础知识整理➣环境搭建和Hello World
  10. shell常用监控脚本