当前位置:首页 > 题解目录 > 正文内容

【题解】游览动物园

亿万年的星光4年前 (2022-01-19)题解目录13638

【题目描述】

动物园有很多游览区,小红已经在动物园的一个游览区游览,突然接到电话,要半个小时内到动物园外面跟一个朋友见面。半个小时小红只够游览完当前区域之后,游览一个最近的景区。已知从一个游览区域只能沿着地图(地图的长宽均小于100)中的直线走(上下左右四个方向),请问离小红当前游览区的最近的一个游览区的坐标是多少,如果有多个点离小红的位置都很近,请输出离出口最近的那个点的坐标(不存在多个点距离出口一样近)?

例如:假设小红在孔雀区(3,2),离小红最近的2处游览区分别是猴山(2,0)和虎山(5,3),但猴山离入口更近,因此输出猴山的坐标。

【输入描述】

第一行2个变量,为小红所在的游览区的坐标

第二行一个整数n,为该动物园内游览区的数量(n<=100)

接下来的n行,每行2个数,代表动物园的n个游览区的坐标(本题所有的坐标值都在1~1000的范围内)

【输出描述】

离小红最近的游览区的坐标。

【样例输入】

3 2
5
2 0 
5 3
3 2
5 5
3 8

【样例输出】

2 0

【题目分析】

  1. 题目比较简单,是求给定坐标和求的坐标之间的距离,不过不是两点之间的距离。

  2. 注意题目要求,只能按照直线走。

  3. 可以定义一个结构体,求出给定坐标x的距离和y的距离,然后计算总和,最后排序。

  4. 注意题目挖的坑,小红本身在景区内,如果单纯输出最近距离,肯定是小红当前位置,所以应该输出第二近的位置。

   5. 此题的疑惑,题目中说 “不存在多个点距离出口一样近

    但是。题目中描述,小红所处位置(3,2)距离(2,0)点是1+2=3。

   (3,2)点距离(5,3)点也是2+1=3。那么输出的是(2,0)。猜想此动物园的入口和出口是同一个地方,坐标点是(0,0)

     因此,我们还要把每个坐标加起来,如果距离一样的情况下,则处理此特殊情况

【参考答案】

#include<bits/stdc++.h>
using namespace std;
int x,y,n;
struct node{
	int x,y; //每个点的坐标 
	int s; //每个点与初始坐标的距离
	int e; //每个点与入口的距离 
};
node m[150];
bool cmp(node a,node b){
	if(a.s!=b.s) return a.s<b.s;
	return a.e<b.e;  //特殊情况,如果距离想等,则判断距离入口的距离。 
}
int main(){
	cin>>x>>y>>n; //输出初始坐标和组数 
	for(int i=0;i<n;i++){
		cin>>m[i].x>>m[i].y;
		m[i].s=abs(m[i].x-x)+abs(m[i].y-y);
		m[i].e=abs(m[i].y)+abs(m[i].x);
	}
	sort(m,m+n,cmp); //排序 
	cout<<m[1].x<<' '<<m[1].y;  //输出第二小的。(因为第一小的一定是本身) 
	return 0;
}



扫描二维码推送至手机访问。

版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

分享给朋友:

相关文章

糖果传递

题目描述有n个小朋友坐成一圈,每人有ai个糖果。每人只能给左右两人传递糖果。每人每次传递一个糖果代价为1。输入格式第一行一个正整数n≤1000000,表示小朋友的个数.接下来n行,每行一个整数ai,表...

【题解】电缆线(2019青岛市程序设计竞赛)

【问题描述】在郊区有N座通信基站,P条双向电缆,第 i 条电缆连接基站 A_i 和 B_i。特别地,1号基站是通信公司的总站,N号基站位于一座农场中。现在,农场主希望对通信线路进行升级,其中升级第 i...

【题解】自动晾衣机

【题目描述】有一个环形可以晾衣服的衣架,有若干个夹子组成,它可以晾不同长度的衣服(占用多个夹子),并且每两件衣服中间要有一个空夹子作为空位,下面需要依次晾干几件长度不一的衣服,请你给出某个夹子的使用情...

【题解】最长上升子序列

【题目描述】一个数的序列bi,当b1<b2<...<bS的时候,我们称这个序列是上升的。对于给定的一个序列(a1,a2,...,aN),我们可以得到一些上升的子序列(ai1,ai2,...

【题解】周末舞会

【题目描述】假设在周末舞会上,男士们和女士们进入舞厅时,各自排成一队。跳舞开始时,依次从男队和女队的队头上各出一人配成舞伴。规定每个舞曲能有一对跳舞者。若两队初始人数不相同,则较长的那一队中未配对者等...

【题解】均分蛋糕

【题解】均分蛋糕

【题目描述】小明的生日要到了!根据习俗,他需要将一些派分给大家。他有 N 个不同口味、不同大小的派。有 F 个朋友会来参加我的派对,每个人会拿到一块派(必须一个...