Description

在平面上堆叠着若干矩形,这些矩形的四边与平面X坐标轴或Y坐标轴平行。下图展示了其中一种情况,3个矩形的边将平面划分成8个区域:



下面展示了另一种稍稍复杂一些的情况:



你的任务是写一个程序,判断这些矩形将平面分成了几个区域。

Input

输入的第一行是一个正整数n(n<=50),分别矩形的数目,接下来的n行,每行有4个用空格分隔的整数li,ti,ri,bi(1<=i<=n)代表了第i个矩形的坐标,(li,ti)代表该矩形左上角的X坐标和Y坐标,(ri,bi)代表该矩形右下角的X坐标和Y坐标,0<=li<ri<=\(10^{6}\),0<=bi<ti<=\(10^{6}\))

Output

输出只有一个整数,代表这些矩形将平面划分成多少区域。

Solution

这道题有两个做法。

首先先将横坐标纵坐标离散化。

第一个做法:

用并查集,将相连的块连接起来,最后查有多少个块

第二个做法:

将边打上标记,将没被打标记的点进行扩散,统计块数

(作者用的是第一个做法)

Code

#include <cstdio>
#include <algorithm>
#define open(x) freopen(x".in","r",stdin);freopen(x".out","w",stdout);
using namespace std;
int i,p,last,fa[500001],n,j,heng,shu,l,r,ans,u,v,bj[500001];
bool bz[1001][1001];
struct re{
int x1,x2,y1,y2;
}a[51];
struct node{
int a,pl;
}k[100001];
const int d[5][2]={{0,0},{-1,0},{1,0},{0,1},{0,-1}};
bool cmp(node x,node y){return x.a<y.a;}
bool rec(node x,node y){return (x.pl<y.pl)||(x.pl==y.pl && x.a<y.a);}
int gf(int x)
{
if (x==fa[x]) return x;
fa[x]=gf(fa[x]);
return fa[x];
}
void ls()
{
sort(k+1,k+2*n+1,cmp);
p=0,last=0;
for (i=1;i<=n+n;i++)
{
if (k[i].a==k[i-1].a) k[i-1].a=last;else
{
k[i-1].a=last;
last=++p;
}
}
k[n+n].a=last;
sort(k+1,k+2*n+1,rec);
}
int main()
{
open("regions");
scanf("%d",&n);
for (i=1;i<=n;i++)
{
scanf("%d%d%d%d",&a[i].x1,&a[i].y1,&a[i].x2,&a[i].y2);
k[i].a=a[i].x1;k[i+n].a=a[i].x2;
k[i].pl=k[i+n].pl=i;
}
ls();
heng=p*2;
for (i=1;i<=n;i++)
{
a[i].x1=k[2*i-1].a*2;a[i].x2=k[2*i].a*2;
}
for (i=1;i<=n;i++)
{
k[i].a=a[i].y1;k[i+n].a=a[i].y2;
k[i].pl=k[i+n].pl=i;
}
ls();
shu=p*2;
for (i=1;i<=n;i++)
{
a[i].y1=k[2*i-1].a*2;a[i].y2=k[2*i].a*2;
}
for (i=1;i<=n;i++)
{
l=a[i].x1;r=a[i].x2;
for (j=a[i].y1;j<=a[i].y2;j++)
bz[l][j]=bz[r][j]=1;
l=a[i].y1;r=a[i].y2;
for (j=a[i].x1;j<=a[i].x2;j++)
bz[j][l]=bz[j][r]=1;
}
for (i=0;i<=heng;i++)
{
for (j=0;j<=shu;j++)
fa[i*shu+j]=i*shu+j;
}
for (i=0;i<=heng;i++)
{
for (j=0;j<=shu;j++)
{
if (bz[i][j]) continue;
for (l=1;l<=4;l++)
{
if (i+d[l][0]<=heng && i+d[l][0]>=0 && j+d[l][1]<=shu && j+d[l][1]>=0)
{
if (!bz[i+d[l][0]][j+d[l][1]])
{
u=gf(i*shu+j);
v=gf((i+d[l][0])*shu+j+d[l][1]);
if(fa[v]!=u) fa[u]=v;
}
}
}
}
}
for (i=0;i<=heng;i++)
{
for (j=0;j<=shu;j++)
{
if (bz[i][j]) continue;
u=gf(i*shu+j);
if (!i || !j || i==heng || j==shu)
{
if (!bj[u])bj[u]=2;
if (bj[u]==1) bj[u]=2,ans--;
}
if (!bj[u])
{
bj[u]=1;
ans++;
}
}
}
printf("%d",ans+1);
return 0;
}

jzoj 6798. 【2014广州市选day2】regions的更多相关文章

  1. jzoj 6797. 【2014广州市选day2】hanoi

    Description 你对经典的hanoi塔问题一定已经很熟悉了.有三根柱子,n个大小不一的圆盘,要求大盘不能压在小盘上,初始时n个圆盘都在第一根柱子上,最少要多少步才能挪到最后一根柱子上? 现在我 ...

  2. 【2014广州市选day1】JZOJ2020年9月12日提高B组T4 字符串距离

    [2014广州市选day1]JZOJ2020年9月12日提高B组T4 字符串距离 题目 Description 给出两个由小写字母组成的字符串 X 和Y ,我们需要算出两个字符串的距离,定义如下: 1 ...

  3. 【2014广州市选day1】JZOJ2020年9月12日提高B组T3 消除游戏

    [2014广州市选day1]JZOJ2020年9月12日提高B组T3 消除游戏 题目 Description 相信大家玩过很多网络上的消除类型的游戏,一般来说就是在一个大拼图内找出相同的部分进行最大程 ...

  4. 【2014广州市选day1】JZOJ2020年9月12日提高B组T2 导弹拦截

    [2014广州市选day1]JZOJ2020年9月12日提高B组T2 导弹拦截 题目 Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统 V1.0.但是这种导弹拦截系统有一个缺 ...

  5. 【JZOJ3601】【广州市选2014】Tree(tree)

    ╰( ̄▽ ̄)╭ 每个非叶子节点,其左右子树叶子节点的权值之和相等.我们称这种二叉树叫平衡二叉树. 我们将一棵平衡二叉树叶子节点的权值从左到右列出来,假如这个权值序列是另一个序列A的子序列,我们称这棵平 ...

  6. SCOI 2014 省选总结

    总的来说作为高一党,去做省选难度的题完全就是去玩的,还是找惯例起身跪hja. 跪毕,看看自己惨不忍睹的成绩,我只想说:电子坑大为什么day1的暴力只有10分!为什么呢?我笑看题面: 方伯伯种玉米,方伯 ...

  7. NOIP 2014 提高组 Day2

    期望得分:100+60+30=190 实际得分:70+60+30=160 https://www.luogu.org/problem/lists?name=&orderitem=pid& ...

  8. JZOJ 1003【东莞市选2007】拦截导弹——dp

    题目:https://jzoj.net/senior/#main/show/1003 只要倒推一下第一次上升的最长和第一次下降的最长就行了.不用n^2logn,枚举了 j 还要用树状数组找值比自己大的 ...

  9. 2014 网选 上海赛区 hdu 5047 Sawtooth

    题意:求n个'M'型的折线将一个平面分成的最多的面数! 思路:我们都知道n条直线将一个平面分成的最多平面数是 An = An-1 + n+1 也就是f(n) = (n*n + n +2)/2 对于一个 ...

随机推荐

  1. C#LeetCode刷题之#16-最接近的三数之和(3Sum Closest)

    目录 问题 示例 分析 问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3620 访问. 给定一个包括 n 个整数的 ...

  2. DRF内置权限组件之自定义权限管理类

    DRF内置权限组件permissions 权限控制可以限制用户对于视图的访问和对于具体数据对象的访问. 在执行视图的dispatch()方法前,会先进行视图访问权限的判断 在通过get_object( ...

  3. JS实例-全选练习

    <!DOCTYPE html><html lang="zh"><head> <meta charset="UTF-8" ...

  4. Ubuntu 18.04 安装、配置和美化

    本文章修改自inkss的博文 为什么要修改原文? 本来我是想自己写这么一篇的,但是没想到在百度一搜,居然一篇好文.我之前没看到,真是可惜. 这篇文章主要是帮助我记录一些东西,如题. 原文虽然不错,但是 ...

  5. Promise.then返回的是什么?

    console.log((function cook(){ console.log('开始做饭.'); var p = new Promise(function(resolve, reject){ / ...

  6. moonlight不显示鼠标指针

    多显示屏导致moonlight不显示鼠标指针, 使用的时候关闭其他显示屏,只使用一个显示屏,就可以正常显示了.

  7. 利用 Github Actions 自动更新 docfx 文档

    利用 Github Actions 自动更新 docfx 文档 Intro docfx 是微软出品一个 .NET API 文档框架,有一个理念是代码即文档,会根据项目代码自动生成 API 文档,即使没 ...

  8. 【Apollo】(2)--- Apollo架构设计

    Apollo架构设计 上一篇博客有讲到:[Apollo](1)--- Apollo入门介绍篇 这篇来写Apollo的核心架构设计 一.整体架构 Apollo整体架构图,已由作者宋顺已经给出: 这幅图所 ...

  9. windows下Nacos集群搭建与nginx集成

    前言: nacos集群至少需要三个(一般为奇数个)nacos实 例,其前面顶nginx,外界入口从nginx入 一.windows下Nacos集群搭建 将Nacos的解压包复制分成3份,分别是: na ...

  10. Navicat15破解+网盘位置

    百度网盘Navicat.15位置 链接:https://pan.baidu.com/s/1Vn0Qnt8IUA37a-p4hAnk5g 提取码:clq3 1.百度网盘下载完后,点这个安装Navicat ...