题目大意:给定平面上的n个点,求一个点到这n个点的切比雪夫距离之和最小

与3170不同的是这次选择的点无需是n个点中的一个

首先将每一个点(x,y)变为(x+y,x-y) 这样新点之间的曼哈顿距离的一半就是原点之间的切比雪夫距离

因为曼哈顿距离中横纵坐标不互相干扰,因此我们能够将横纵坐标分开处理

每一维要选一个坐标 到其它全部坐标的绝对值之和相等 非常easy想到中位数

可是直接选择中位数得到的点可能横纵坐标奇偶性不同 这样代回原点中发现不是整点

因此假设得到的点横纵坐标奇偶性同样直接输出距离 不同的话选择周围的四个点进行判定 选择最小的距离输出就可以

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#define M 100100
using namespace std;
int n,X[M],Y[M];
long long Check(int x,int y)
{
int i;
long long re=0;
for(i=1;i<=n;i++)
re+=abs(x-X[i])+abs(y-Y[i]);
return re;
}
int main()
{
int i,x,y;
cin>>n;
for(i=1;i<=n;i++)
{
scanf("%d%d",&x,&y);
X[i]=x+y;Y[i]=x-y;
}
sort(X+1,X+n+1);
sort(Y+1,Y+n+1);
x=X[n+1>>1];
y=Y[n+1>>1];
if( ~(x^y)&1 )
cout<<Check(x,y)/2<<endl;
else
cout<<min(min(Check(x+1,y),Check(x-1,y)),min(Check(x,y+1),Check(x,y-1)))/2<<endl;
return 0; }

最新文章

  1. PHP的GD库
  2. Ubuntu 14.04 安装VMware 12
  3. python核心编程第六章练习6-15
  4. C++命名空间
  5. Android中ScrollView嵌套GridView,解决GridView显示不全的问题
  6. [技巧]实际项目中background-image应写在页面上
  7. 2015最新百度搜索引擎(seo优化)排名算法
  8. Java笔记——JavaMail发送邮件
  9. General: Know How to Use InetAddress
  10. linux route 路由设置小记
  11. 菜鸟博客装饰分享CSS+HTML+js
  12. Linux编程 16 文件权限(组管理 groupadd, groupmod,文件权限介绍)
  13. python3数据结构与算法
  14. Eclipse无法自动编译生成class文件
  15. 【转】Java十大常用框架介绍(spring系+dubbo+RabbitMQ+Ehcache+redis)
  16. MySQL提示“错误2:系统找不到指定文件”
  17. CSS实现三角形、梯形、平行四边形、圆形、椭圆形、对话框、自适应正方形
  18. SpringBoot实战(二)之计划任务
  19. 轻量ORM-SqlRepoEx (十五)最佳实践之数据映射(Map)
  20. 将SVM用于多类分类

热门文章

  1. vue --- 路由传参的几种方式
  2. Optional arguments
  3. Mysql-in查询问题
  4. Hive框架基础(一)
  5. MyBatis+mysql查询和添加数据
  6. GPU Command Buffer
  7. MySQL服务启动:某些服务在未由其他服务或程序使用时将自动停止
  8. Mac配置PHP环境
  9. vue单页面前端做非空校验
  10. django 在非空的字段里插入现象表述