zoj 3041 City Selection

题意:现在有m个工厂和n个可建城市的地点,每个工厂能影响自己右下方的所有空间(即四分之一个角),而被影响的去区域无法建城市。输出所有可以建城市的点及其数量.

首先我们可以得到的是,工厂x坐标<=城市x坐标 && 工厂y坐标 >= 城市y坐标,那么是无法建的。那么接下来,无论是x 维优先还是y维优先,我们将所有的城市和工厂按照一个优先级排序(假设这里是x优先),都可以得到一个有序的序列,在这里是x从小到大,x相同时y从小到大。(便于答案输出)

那么接下来遍历所有的点,最开始说过,城市能建的话要满足两个条件之一即可,即x<工厂的x,或者y>工厂的y.而经过排序之后,对于当前第c个城市(假如),x坐标肯定是大于之前的工厂的x,我们只要确定是否有一个工厂的y坐标小于c城市的y坐标就行。另外遍历的同时更新工厂的y

#include <map>
#include <set>
#include <queue>
#include <stack>
#include <vector>
#include <cmath>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>

using namespace std;

#define lson l, mid, rt << 1
#define rson mid + 1, r, rt << 1 | 1
#define pi acos(-1.0)
#define eps 1e-8
typedef long long ll;
const int inf = 0x3f3f3f3f;

const int N = 200020;

struct node{
	int x, y;
	bool f;
	bool operator < ( const node &b )const
	{
		if( x == b.x )
		{
			if( y == b.y )
				return f;
			else
				return y < b.y;
		}
		else
			return x < b.x;
	}
}a[N * 2];

int n, m;

int main()
{
	while(~scanf("%d%d", &n, &m))
	{
		for( int i = 0; i < n; i++ )
		{
			scanf("%d %d", &a[i].x, &a[i].y);
			a[i].f = 0;	//city
		}
		for( int i = n; i < n + m; i++ )
		{
			scanf("%d %d", &a[i].x, &a[i].y);
			a[i].f = 1;	//fc
		}
		sort( a, a + n + m );
		int ans = 0, y = -inf;
		for( int i = 0; i < n + m; i++ )
		{
			if( a[i].f )
				y = max( y, a[i].y );
			else
			{
				if( a[i].y > y )
					a[ans++] = a[i];
			}
		}
		printf("%d\n", ans);
		for( int i = 0; i < ans; i++ )
		{
			printf("%d %d\n", a[i].x, a[i].y);
		}
	}
	return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值