博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
bzoj3210 花神的浇花集会 坐标
阅读量:4311 次
发布时间:2019-06-06

本文共 1374 字,大约阅读时间需要 4 分钟。

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

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

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

由于曼哈顿距离中横纵坐标不互相干扰,因此我们可以将横纵坐标分开处理

每一维要选一个坐标 到其他所有坐标的绝对值之和相等 很容易想到中位数

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

因此如果得到的点横纵坐标奇偶性相同直接输出距离 不同的话选择周围的四个点进行判定 选择最小的距离输出即可

 

1 #include
2 #include
3 #include
4 #include
5 #include
6 7 #define ll long long 8 #define N 100007 9 using namespace std;10 inline int read()11 {12 int x=0,f=1;char ch=getchar();13 while(ch<'0'||ch>'9'){
if (ch=='-') f=-1;ch=getchar();}14 while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+ch-'0';ch=getchar();}15 return x*f;16 }17 18 int n;19 int x[N],y[N];20 double a[N],b[N];21 ll ans=1e60;22 23 void solve(int kx,int ky)24 {25 ll res=0;26 for (int i=1;i<=n;i++)27 res+=max(abs(kx-a[i]),abs(ky-b[i]));28 ans=min(res,ans);29 }30 int main()31 {32 n=read();33 for (int i=1;i<=n;i++)34 {35 a[i]=read(),b[i]=read();36 x[i]=(a[i]+b[i])*0.5,y[i]=(a[i]-b[i])*0.5;37 }38 sort(x+1,x+n+1),sort(y+1,y+n+1);39 int kx=x[n/2]+y[n/2+1],ky=x[n/2+1]-y[n/2+1];40 for (int i=kx-1;i<=kx+1;i++)41 for (int j=ky-1;j<=ky+1;j++) solve(i,j);42 printf("%lld",ans);43 }

 

转载于:https://www.cnblogs.com/fengzhiyuan/p/8185139.html

你可能感兴趣的文章
python unittest学习1---重要的几个概念
查看>>
MapReduce编程之Reduce Join多种应用场景与使用
查看>>
干货: 可视化项目实战经验分享,轻松玩转 Bokeh (建议收藏)
查看>>
使用pyinstaller打包多个py文件为一个EXE文件
查看>>
书接前文,用多进程模式实现fibonnachi并发计算
查看>>
numpy的数组常用运算练习
查看>>
ExtJs之DHTML,DOM,EXTJS的事件绑定区别
查看>>
Leetcode:Toeplitz Matrix
查看>>
js定时器
查看>>
Android官方文档
查看>>
tcp/udp协议代码实现
查看>>
python---django中orm的使用(2)
查看>>
读书时间《JavaScript高级程序设计》四:BOM,客户端检测
查看>>
Linux基础命令---free显示内存使用
查看>>
转:CentOS---网络配置详解
查看>>
绕任意单位轴旋转矩阵计算
查看>>
洛谷P2502[HAOI2006]旅行
查看>>
Linux 配置mail发送邮件
查看>>
Linux 正则
查看>>
织梦网站搬家,数据库无法导入的解决方法
查看>>