BZOJ 3210 花神的浇花集会 计算几何- -?

题目大意:给定平面上的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;

}
时间: 2024-08-08 05:34:20

BZOJ 3210 花神的浇花集会 计算几何- -?的相关文章

BZOJ 3210: 花神的浇花集会

3210: 花神的浇花集会 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 577  Solved: 299[Submit][Status][Discuss] Description 在花老师的指导下,每周4都有一个集会活动,俗称“浇水”活动. 具体浇水活动详情请见BZOJ3153 但这不是重点 花神出了好多题,每道题都有两个参考系数:代码难度和算法难度 花神为了准备浇花集会的题,必须找一道尽量适合所有人的题 现在花神知道每个人的代码能力x和算法能力

BZOJ 3210 花神的浇花集会 切比雪夫距离

题目大意:平面上一些点,求一个点到所有点的切比雪夫距离只和最小. 思路:和那个松鼠的题目比较像,但是松鼠的那个是求的点是所有点中的一个点,而这个题却不一定.和那个题一样,将横纵坐标分别排序,然后取中位数统计.但是有可能会出现小数,因此随即调整一下,取最小值就行了. CODE: #include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #define MAX 10

【BZOJ】【3210】花神的浇花集会

曼哈顿距离与切比雪夫距离 QAQ蒟蒻并不知道切比雪夫距离是什么……并不会做这道题…… 去膜拜了PoPoQQQ大爷的题解: 题目大意:给定平面上的n个点,求一个点到这n个点的切比雪夫距离之和最小 与3170不同的是这次选择的点无需是n个点中的一个 首先将每个点(x,y)变为(x+y,x-y) 这样新点之间的曼哈顿距离的一半就是原点之间的切比雪夫距离 由于曼哈顿距离中横纵坐标不互相干扰,因此我们可以将横纵坐标分开处理 每一维要选一个坐标 到其他所有坐标的绝对值之和相等 很容易想到中位数 但是直接选择

BZOJ3210: 花神的浇花集会

Description   在花老师的指导下,每周4都有一个集会活动,俗称“浇水”活动. 具体浇水活动详情请见BZOJ3153 但这不是重点 花神出了好多题,每道题都有两个参考系数:代码难度和算法难度 花神为了准备浇花集会的题,必须找一道尽量适合所有人的题 现在花神知道每个人的代码能力x和算法能力y,一道题(代码难度X算法难度Y)对这个人的不适合度为    Max ( abs ( X – x ) , abs ( Y – y ) ) 也就是说无论太难还是太简单都会导致题目不适合做(如果全按花神本人

【bzoj3210】花神的浇花集会 数论

题目描述 在花老师的指导下,每周4都有一个集会活动,俗称“浇水”活动. 具体浇水活动详情请见BZOJ3153 但这不是重点 花神出了好多题,每道题都有两个参考系数:代码难度和算法难度 花神为了准备浇花集会的题,必须找一道尽量适合所有人的题 现在花神知道每个人的代码能力x和算法能力y,一道题(代码难度X算法难度Y)对这个人的不适合度为    Max ( abs ( X – x ) , abs ( Y – y ) ) 也就是说无论太难还是太简单都会导致题目不适合做(如果全按花神本人能力设题,绝对的全

BZOJ_3210_花神的浇花集会_切比雪夫距离

Description 在花老师的指导下,每周4都有一个集会活动,俗称“浇水”活动. 具体浇水活动详情请见BZOJ3153 但这不是重点 花神出了好多题,每道题都有两个参考系数:代码难度和算法难度 花神为了准备浇花集会的题,必须找一道尽量适合所有人的题 现在花神知道每个人的代码能力x和算法能力y,一道题(代码难度X算法难度Y)对这个人的不适合度为    Max ( abs ( X – x ) , abs ( Y – y ) ) 也就是说无论太难还是太简单都会导致题目不适合做(如果全按花神本人能力

【bzoj3210】花神的浇花集会

将(x,y)转化成(x+y,x-y)可以将切比雪夫距离转化成曼哈顿距离(自己推一推) A.B的切比雪夫距离就是A‘.B‘曼哈顿距离的一半. 那么可以将x.y分离处理,排序中位数即可. 注意如果最后选的最优的X.Y代回去不是整数,要在其上下左右中选个最优方案. #include<algorithm> #include<iostream> #include<cstdlib> #include<cstring> #include<cstdio> #in

bzoj3210 花神的浇花集会 坐标

题目大意:给定平面上的n个点,求一个点到这n个点的切比雪夫距离之和最小 与3170不同的是这次选择的点无需是n个点中的一个 首先将每个点(x,y)变为(x+y,x-y) 这样新点之间的曼哈顿距离的一半就是原点之间的切比雪夫距离 由于曼哈顿距离中横纵坐标不互相干扰,因此我们可以将横纵坐标分开处理 每一维要选一个坐标 到其他所有坐标的绝对值之和相等 很容易想到中位数 但是直接选择中位数得到的点可能横纵坐标奇偶性不同 这样代回原点中发现不是整点 因此如果得到的点横纵坐标奇偶性相同直接输出距离 不同的话

BZOJ:3209: 花神的数论题

今天居然没参考任何资料解决了这道数位DP,事先只是搞一道数论题练练: 思路:求SUM[1]-SUM[N]的二进制的乘积mod1000000007: N<=10^15;BZOJ的题不会是几个简单的FOR就完结的, 假如N的二进制是:1001001: 位数:1234567 那么当第一位是0的情况:那么数就是000000-111111 序列号:  123456-123456 发现我们可以用排列组合算出二进制有1-6个1的数比如:1个1就是C[6][1],2个1就是C[6][2],...... 当第一位