我是靠谱客的博主 温暖老师,最近开发中收集的这篇文章主要介绍暑期集训积分赛(二) D. Points in rectangle,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

暑期集训积分赛(二) D. Points in rectangle
题目:
在二维平面中有一个矩形,它的四个坐标点分别为(0,a),(a,0),(n,n−a),(n−a,n)。你现在有m个点,现在你想知道有多少个点是在这个矩形内的(边上的也算)。
输入格式:
第一行输入n,a(1≤a<n≤103)。
第二行一个正整数m(1≤m≤103),代表你拥有的点的个数,接下来m行,每行一个点的坐标xi,yi(1≤xi,yi≤103)
输出格式:
第一行输出在矩形内的点的个数,然后输出在矩形内点的坐标,横坐标大的优先,如果横坐标相同,则纵坐标大的优先。如果没有,输出−1。
input:
6 1
5
1 2
1 3
2 3
3 4
4 5
output:
4
4 5
3 4
2 3
1 2
//用优先队列
代码+解释:

#include<iostream>
#include<algorithm>
#include<queue>
#include<cstring>
#include<cmath>
using namespace std;
struct node
{
	double x;
	double y;//记录坐标对 
	/*bool operator<(const node & p)const//此行<符号不能改变  A
	{  
		if(x==p.x)
			return y<p.y;//如果横坐标相同 ,则按纵坐标降序排列
		else
			return x<p.x;//按横坐标降序排列
	}*/
	bool operator<(const node & p)const//此行<符号不能改变  B
	{  
		if(x==p.x)
			return y>p.y;//如果横坐标相同 ,则按纵坐标升序排列
		else
			return x>p.x;//按横坐标升序排列
	}
	/*bool friend operator<(node a,node b)//此行<符号不能改变  C
	{
		if(a.x==b.x)
			return a.y<b.y;//如果横坐标相同 ,则按纵坐标降序排列
		else
			return a.x<b.y;//按横坐标降序排列 
	}*/
	/*bool friend operator<(node a,node b)//此行<符号不能改变  D
	{
		if(a.x==b.x)
			return a.y>b.y;//如果横坐标相同 ,则按纵坐标升序排列
		else
			return a.x>b.y;//按横坐标升序排列 
	}*/
	//以上两种重载形式均可 
};
//6 1 6 1 2 1 3 2 3 3 4 4 5 4 4.5
int main()
{
	double n,a;
	int m;
	double x,y;
	priority_queue<node>que;//定义一个优先队列
	while(cin>>n>>a>>m)
	{
		int count=0; 
		for(int i=0;i<m;i++)//一共有点m个,循环m次
		{
			node p;//定义一个结构体 
			cin>>x>>y;
			p.x=x;
			p.y=y;//存入 
			if(y<=x+a && y>=x-a && y<=2*n-a-x && y>=a-x)//判定是否在矩形
			{
				count++;//每满足一个数次数就加一 
				que.push(p);//如果坐标满足条件,就把坐标放进队列 
			}
		}
		//把所有的坐标对存入结构体放进队列之后
		if(count==0)
			cout<<"-1"<<endl;
		else
		{
			cout<<count<<endl;
			for(int i=0;i<count;i++)
			{
				node q=que.top();
				cout<<q.x<<" "<<q.y<<endl;
				que.pop();//清空 
				//在队列输出过程中,以运行B为例
				//测试数据:
				//6 1 
				//6 
				//1 2 
				//1 3 
				//2 3 
				//3 4 
				//4 5 
				//4 4.5
				//输出:
				//5
				//1 2
				//3 4
				//2 3
				//4 4.5
				//4 5 
				//if(x==p.x)
				//	return y>p.y;//如果横坐标相同 ,则按纵坐标升序排列,当横坐标相同时纵坐标越小的先出列 
				//else
				//	return x>p.x;//按横坐标升序排列,说明横坐标越小先出列 
			}	
		}
		
	}
	return 0;
}

最后

以上就是温暖老师为你收集整理的暑期集训积分赛(二) D. Points in rectangle的全部内容,希望文章能够帮你解决暑期集训积分赛(二) D. Points in rectangle所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(37)

评论列表共有 0 条评论

立即
投稿
返回
顶部