圈水池
时间限制:
3000 ms | 内存限制:
65535 KB
难度:
4
-
描述
-
有一个牧场,牧场上有很多个供水装置,现在牧场的主人想要用篱笆把这些供水装置圈起来,以防止不是自己的牲畜来喝水,各个水池都标有各自的坐标,现在要你写一个程序利用最短的篱笆将这些供水装置圈起来!(篱笆足够多,并且长度可变)
-
输入
-
第一行输入的是N,代表用N组测试数据(1<=N<=10)
第二行输入的是m,代表本组测试数据共有m个供水装置(3<=m<=100)
接下来m行代表的是各个供水装置的横纵坐标
输出
- 输出各个篱笆经过各个供水装置的坐标点,并且按照x轴坐标值从小到大输出,如果x轴坐标值相同,再安照y轴坐标值从小到大输出 样例输入
-
1 4 0 0 1 1 2 3 3 0
样例输出
-
0 0 2 3 3 0
来源
- [张洁烽]原创 上传者
-
第一行输入的是N,代表用N组测试数据(1<=N<=10)
思路:这个题其实不难,主要的思路是,建立一个四边形的圈水池,这个圈水池在数轴上,因此只要求出四个角的点就行了,然后用一个
sort加一个cmp调用函数就可以了,最后输出的时候判断,是否在四条边上就可以了;
#include<stdio.h>
#include<algorithm>
using namespace std;
struct note
{
int x,y;
}que[1100];
bool cmp(note a,note b)
{
if(a.x!=b.x)
return a.x<b.x;
else return a.y<b.y;
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
int n,i;
int max1=-999999,max2=-99999,min1=999999,min2=999999;
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%d %d",&que[i].x,&que[i].y);
if(que[i].x>max1)max1=que[i].x; //找出四个点,建立一个四边形
if(que[i].x<min1)min1=que[i].x; //且这四个点必须是x,y数轴上的最大和最小的,
if(que[i].y>max2)max2=que[i].y; //这样才能把所有的供水装置圈进去。
if(que[i].y<min2)min2=que[i].y;
}
sort(que,que+n,cmp); //按照所要求的进行排序。
for(i=0;i<n;i++)
{
if(que[i].x==max1||que[i].x==min1||que[i].y==max2||que[i].y==min2)
printf("%d %d\n",que[i].x,que[i].y); //判断是否在四个边上
}
}
return 0;
}