题目链接:

id=3168">POJ 3168 Barn Expansion

题意:抽象出来就是给出n个矩形的坐标是(左下角和右上角的坐标,矩形的边都是平行x,y轴),问有几个矩形和其它矩形没有接触(仅仅存在边接触或者点接触,不存在有公共面积)。

思路:把边分成两类,平行x轴和平行y轴。对边进行排序。然后for一遍推断是否有相交就可以

AC代码:

#include <stdio.h>
#include <vector>
#include <map>
#include <set>
#include <algorithm>
using namespace std; struct node {
int mark;
int d,xx,yy;
node() {}
node(int _d,int _xx,int _yy,int _mark) {
d=_d,xx=_xx,yy=_yy,mark=_mark;
}
}; vector<node> sx,sy;
bool vis[25010];
bool cmp(node a,node b) {
if(a.d!=b.d) return a.d<b.d;
else if(a.xx!=b.xx) return a.xx<b.xx;
else return a.yy<b.yy;
} int main() {
int n;
int i,j,k;
int a,b,c,d;
while(scanf("%d",&n)!=EOF) {
sx.clear();
sy.clear();
memset(vis,false,sizeof vis);
for(i=0; i<n; i++) {
scanf("%d %d %d %d",&a,&b,&c,&d);
sy.push_back(node(b,a,c,i));
sy.push_back(node(d,a,c,i));
sx.push_back(node(a,b,d,i));
sx.push_back(node(c,b,d,i));
}
int sz1,sz2;
sz1=sy.size();
sz2=sx.size();
sort(sx.begin(),sx.end(),cmp);
sort(sy.begin(),sy.end(),cmp); //竖 y<yy
int up;
up=sy[0].yy;
for(i=1;i<sz1;i++){
if(sy[i-1].d == sy[i].d){
if(up >= sy[i].xx){
vis[sy[i].mark]=vis[sy[i-1].mark]=true;
}
}
else up=sy[i].yy;
up=max(sy[i].yy,up);
}
up=sx[0].yy;
for(i=1;i<sz2;i++){
if(sx[i-1].d == sx[i].d){
if(up >= sx[i].xx){
vis[sx[i].mark]=vis[sx[i-1].mark]=true;
}
}
else up=sx[i].yy;
up=max(sx[i].yy,up);
}
int ans=0;
for(i=0;i<n;i++){
if(!vis[i]) ans++;
}
printf("%d\n",ans);
}
return 0;
}
/*
5
0 2 2 7
3 5 5 8
4 2 6 4
6 1 8 6
0 0 8 1 4
2 1 3 2
2 2 3 3
3 3 4 4
4 1 5 2 9
0 0 1 1
1 0 2 1
2 0 3 1
0 1 1 2
1 1 2 2
2 1 3 2
0 2 1 3
1 2 2 3
2 2 3 3 6
0 2 2 7
3 5 5 8
4 2 6 4
6 1 8 6
0 0 8 1
4 5 5 6 3
1 1 6 6
6 2 7 3
6 5 8 7
*/

POJ 3168 Barn Expansion (几何+排序)的更多相关文章

  1. poj 3168 Barn Expansion 几何yy

    题链:http://poj.org/problem? id=3168 Barn Expansion Time Limit: 1000MS   Memory Limit: 65536K Total Su ...

  2. poj 3168 Barn Expansion

    Barn Expansion Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 2465   Accepted: 666 Des ...

  3. POJ 3168 Barn Expansion (几何基础)

    [题目链接] http://poj.org/problem?id=3168 [题目大意] 给出一些矩形,没有相交和包含的情况,只有相切的情况 问有多少个矩形没有相切或者边角重叠 [题解] 我们将所有的 ...

  4. POJ 3168 排序+扫描

    题意: 思路: 我们可以把每个矩形拆成四条线 与x轴平行的放在一起 与y轴平行的放在一起 排个序 判一判有没有交 有交 则说明不可扩张 统计一下 就可以了 处理的姿势很重要 姿势不对毁一生 //By ...

  5. POJ 2367 (裸拓扑排序)

    http://poj.org/problem?id=2367 题意:给你n个数,从第一个数到第n个数,每一行的数字代表排在这个行数的后面的数字,直到0. 这是一个特别裸的拓扑排序的一个题目,拓扑排序我 ...

  6. poj 3687 Labeling Balls(拓扑排序)

    题目:http://poj.org/problem?id=3687题意:n个重量为1~n的球,给定一些编号间的重量比较关系,现在给每个球编号,在符合条件的前提下使得编号小的球重量小.(先保证1号球最轻 ...

  7. Poj 2371 Questions and answers(排序)

    题目链接:http://poj.org/problem?id=2371 思路分析:使用计数排序或其他时间复杂度为O( log N )的排序. 代码如下: #include <iostream&g ...

  8. [ACM] POJ 3687 Labeling Balls (拓扑排序,反向生成端)

    Labeling Balls Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10161   Accepted: 2810 D ...

  9. poj 2762(强连通分量+拓扑排序)

    题目链接:http://poj.org/problem?id=2762 题意:给出一个有向图,判断任意的两个顶点(u,v)能否从u到达v,或v到达u,即单连通,输出Yes或No. 分析:对于同一个强连 ...

随机推荐

  1. 〖C++〗string2int把字符串转换成int的函数

    #include <stdio.h> #include <stdlib.h> #include <string.h> int string2int(char *ar ...

  2. 【TP3.2】路由匹配和规则

    TP3.2框架的路由匹配和规则处理: 包括:静态路由,动态路由,多参数路由.正则路由 <?php return array( //'配置项'=>'配置值' /* * 路由开启和匹配.首先开 ...

  3. 【转载】Redis在windows下安装过程

    一.下载windows版本的Redis 去官网找了很久,发现原来在官网上可以下载的windows版本的,现在官网以及没有下载地址,只能在github上下载,官网只提供linux版本的下载 官网下载地址 ...

  4. PHP部分常见算法

    撰于:http://blog.csdn.net/caleng/article/details/5276403

  5. 使用阿里云Docker镜像加速

    使用docker官方的docker hub速度太慢,正好看到国内阿里云也做了docker镜像,于是想试试看阿里云的docker源.先附上 阿里云docker hub地址 .新用户需要注册成为开发者.打 ...

  6. [Jobdu] 题目1504:把数组排成最小的数

    题目描述: 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个.例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323. 输入: 输 ...

  7. js操作cookie的一些注意项

     这两天做购物车逻辑.依照通常的做法,把预购信息存放在cookie里,结果发生了非常多不可理喻的事情,完整的证明了我对cookie的无知. . . 这么多年.非常少用cookie,由于认为它不安全 ...

  8. shell判断文件夹是否存在

    #shell判断文件夹是否存在 #如果文件夹不存在,创建文件夹 if [ ! -d "/myfolder" ]; then mkdir /myfolder fi #shell判断文 ...

  9. linux中录屏工具byzanz

    linux中录屏工具byzanz: 1.安装 sudo apt install byzanz 2.使用 help:byzanz-record --help 配合xwininfo使用--xwininfo ...

  10. inline函数出现 undefined reference 错误

    原因:你把inline函数的implementation放到cpp文件里肯定要报这个错误 正确的做法:把inline函数的声明和实现都放到header里,例如 // declaration: retu ...