题目传送门

松鼠聚会

题目描述

草原上住着一群小松鼠,每个小松鼠都有一个家。时间长了,大家觉得应该聚一聚。但是草原非常大,松鼠们都很头疼应该在谁家聚会才最合理。

每个小松鼠的家可以用一个点x,y表示,两个点的距离定义为点(x,y)和它周围的8个点(x-1,y)(x+1,y),(x,y-1),(x,y+1).(x-1,y+1),(x-1,y-1),(x+1,y+1),(x+1,y-1)距离为1。

输入输出格式

输入格式:

第一行是一个整数N,表示有多少只松鼠。接下来N行,第i行是两个整数x和y,表示松鼠i的家的坐标

输出格式:

一个整数,表示松鼠为了聚会走的路程和最小是多少。

输入输出样例

输入样例#1:

6
-4 -1
-1 -2
2 -4
0 2
0 3
5 -2
输出样例#1:

20
输入样例#2:

6
0 0
2 0
-5 -2
2 -2
-1 2
4 0
输出样例#2:

15

说明

样例解释

在第一个样例中,松鼠在第二只松鼠家(-1,-2)聚会;在第二个样例中,松鼠在第一只松鼠家(0.0)聚会。

数据范围

30%的数据,0 ≤ N ≤ 1000

100%的数据,0 ≤ N ≤ 100000; −10^9 ≤ x, y ≤ 10^9


  分析:

  这道奇妙的题让蒟蒻认识了切比雪夫距离这个奇妙的东西,关于切比雪夫距离可以参照julao的博客

  关于这道题,我们把切比雪夫距离转换成曼哈顿距离,然后用前缀和+二分答案优化一下就可以了。

  Code:

//It is made by HolseLee on 6th Nov 2018
//Luogu.org P3964
#include<bits/stdc++.h>
using namespace std; typedef long long ll;
const int N=1e5+;
int n,x[N],y[N],px[N],py[N];
ll sumx[N],sumy[N],ans; inline int read()
{
char ch=getchar(); int x=; bool flag=false;
while( ch<'' || ch>'' ) {
if( ch=='-' ) flag=true; ch=getchar();
}
while( ch>='' && ch<='' ) {
x=x*+ch-''; ch=getchar();
}
return flag ? -x : x;
} void getsum()
{
for(int i=; i<=n; ++i) sumx[i]=sumx[i-]+x[i];
for(int i=; i<=n; ++i) sumy[i]=sumy[i-]+y[i];
} inline ll binary_x(int u)
{
ll l=, r=n, mid,ret=n;
while( l<=r ) {
mid=(l+r)>>;
if( x[mid]<=px[u] ) ret=mid, l=mid+;
else r=mid-;
}
return ret;
} inline ll binary_y(int u)
{
ll l=, r=n, mid,ret=n;
while( l<=r ) {
mid=(l+r)>>;
if( y[mid]<=py[u] ) ret=mid, l=mid+;
else r=mid-;
}
return ret;
} inline ll getans(int u)
{
ll xpos=binary_x(u);
ll ansx=xpos*px[u]-sumx[xpos]+sumx[n]-sumx[xpos]-(n-xpos)*px[u];
ll ypos=binary_y(u);
ll ansy=ypos*py[u]-sumy[ypos]+sumy[n]-sumy[ypos]-(n-ypos)*py[u];
return ansx+ansy;
} int main()
{
n=read(); int a,b;
for(int i=; i<=n; ++i) {
a=read(), b=read();
x[i]=px[i]=a+b; y[i]=py[i]=a-b;
}
sort(x+,x+n+); sort(y+,y+n+);
getsum();
ans=1e18;
for(int i=; i<=n; ++i) {
ll now=getans(i);
ans=min(now,ans);
}
printf("%lld\n",ans>>1ll);
return ;
}

最新文章

  1. REDIS源码中一些值得学习的技术细节01
  2. JavaScript高级程序设计学习笔记--面向对象程序设计
  3. poj2184 01背包变形,价值为可为负数
  4. CentOS6.5 Openssl版本升级
  5. JQuery源码分析(三)
  6. linux初学 :简易的shell脚本
  7. Spring注释@Qualifier
  8. Linux 基础 —— RPM
  9. js修改input的type属性问题
  10. HDOJ/HDU 1241 Oil Deposits(经典DFS)
  11. Wireshark入门与进阶系列(二)
  12. HDU 4359 Easy Tree DP? 带权二叉树的构造方法 dp
  13. 烧录口被初始化为普通IO
  14. 字符串拼接data-id时注意事项
  15. jQuery 效果 – 滑动
  16. CentOS7 添加开机启动项
  17. Advanced Electronic Engineer
  18. 简单的HTML5 canvas游戏工作原理
  19. Java——使用File类递归遍历指定路劲下的所有文件
  20. Partition List leetcode java

热门文章

  1. 【bzoj4765】 普通计算姬
  2. LeetCode 8 有效的括号
  3. vue+webpack开发(一)
  4. Git 配置环境及常用命令整理
  5. js 正则之 检测素数
  6. plsql免安装客户端的配置
  7. Guava HashMultiMap(MultiMap)反转映射
  8. 鼠标样式 cursor 全总结
  9. 第11月第31天 keyboardwillshow CGAffineTransformMakeTranslation
  10. 第10月第20天 afnetwork like MKNetworkEngine http post