涂色:(日文题目,自己翻译成了中文)为了宣传信息竞赛,要在长方形的三合板上喷油漆来制作招牌。三合板上不需要涂色的部分预先贴好了护板。被护板隔开的区域要涂上不同的颜色,比如上图就应该涂上5种颜色。

请编写一个程序计算涂色数量,输入数据中,保证看板不会被护板全部遮住,并且护板的边一定是水平或垂直的。

输入:

第一个数是宽w(1 ≤ w ≤ 1000000),第二个数是高h(1 ≤ h ≤ 1000000)。

第二行是护板的数量n(1 ≤ n ≤ 1000),接着n行是每个护板的左下角坐标 (x1 , y1 )和右上角坐标 (x2 , y2 ),用空格隔开: x1 , y1 , x2 , y2 (0 ≤ x1< x2 ≤ w, 0 ≤ y1 < y2 ≤ h 都是整数)

招牌的坐标系如下,左下角是 (0, 0) ,右上角是(w, h) , 测试集中的30%都满足w ≤ 100, h ≤ 100, n ≤ 100。

输出:

一个整数,代表涂色数量。

使用坐标离散化求解。

坐标离散化的思想是:当坐标范围很大而坐标数量很少时,可以考虑把所有用到的横坐标排序,然后用每个坐标对应的下标来更新坐标位置。

举例来说:

这个例子中的用到的横坐标有1,2,4,5,6,7,9,10,11,12,13,14。

那么横坐标对(1,5)就可以转化为(0,3)。节省了一位空间,这个节省在空隙变大后会越来越明显。

通过坐标离散化,通常时间复杂度就可以降到令人满意的程度了。

这里使用了imos法,进一步优化时间复杂度。

接下来是代码,来自http://www.hankcs.com/program/algorithm/aoj-0531-paint-color.html

 #include<iostream>
#include<vector>
#include<algorithm>
#include<queue>
#include <cstring>
#define MAX_N 1000 + 16 using namespace std; int N, H, W;
int X1[MAX_N], X2[MAX_N], Y1[MAX_N], Y2[MAX_N];
int fld[ * MAX_N][ * MAX_N], // 填充遍历用,代表坐标(i, j)处是否空白(压缩后)
dx[] = { , -, , }, dy[] = { , , , - }; // 压缩坐标,将坐标的值变成“这是第几种值”,返回一共有几种坐标
int compress(int *x1, int *x2, int w)
{
vector<int>xs; for (int i = ; i < N; ++i)
{
int tx1 = x1[i], tx2 = x2[i];
if ( <= tx1 && tx1 < w) xs.push_back(tx1);
if ( <= tx2 && tx2 < w) xs.push_back(tx2);
}
xs.push_back();
xs.push_back(w);
sort(xs.begin(), xs.end());
xs.erase(unique(xs.begin(), xs.end()), xs.end());
for (int i = ; i < N; ++i)
{
x1[i] = find(xs.begin(), xs.end(), x1[i]) - xs.begin();
x2[i] = find(xs.begin(), xs.end(), x2[i]) - xs.begin();
}
return xs.size() - ;
} int bfs()
{
int ans = ;
for (int i = ; i < H; ++i)
{
for (int j = ; j < W; ++j)
{
if (fld[i][j]) continue;
++ans;
queue<pair<int, int> >que;
que.push(make_pair(j, i));
while (!que.empty())
{
int nx = que.front().first, ny = que.front().second;
que.pop(); for (int i = ; i < ; ++i)
{
int tx = nx + dx[i], ty = ny + dy[i];
if (tx < || W < tx || ty < || H< ty || fld[ty][tx] > ) continue;
que.push(make_pair(tx, ty));
fld[ty][tx] = ;
}
}
}
}
return ans;
} ///////////////////////////SubMain//////////////////////////////////
int main(int argc, char *argv[])
{
while (cin >> W >> H, W | H)
{
cin >> N;
for (int i = ; i < N; ++i)
{
cin >> X1[i] >> Y1[i] >> X2[i] >> Y2[i];
} memset(fld, , sizeof(fld)); W = compress(X1, X2, W);
H = compress(Y1, Y2, H); // imos-法
for (int i = ; i < N; i++)
{
fld[Y1[i]][X1[i]]++;
fld[Y1[i]][X2[i]]--;
fld[Y2[i]][X1[i]]--;
fld[Y2[i]][X2[i]]++;
}
// 横向累积
for (int i = ; i < H; i++)
{
for (int j = ; j < W; j++)
{
fld[i][j] += fld[i][j - ];
}
}
// 纵向累积
for (int i = ; i < H; i++)
{
for (int j = ; j < W; j++)
{
fld[i][j] += fld[i - ][j];
}
}// 累积完后,fld中非0部分表示有挡板
cout << bfs() << endl;
}
return ;
}
///////////////////////////End Sub//////////////////////////////////

AOJ 0531 坐标离散化的更多相关文章

  1. Aizu 0531 "Paint Color" (坐标离散化+DFS or BFS)

    传送门 题目描述: 为了宣传信息竞赛,要在长方形的三合板上喷油漆来制作招牌. 三合板上不需要涂色的部分预先贴好了护板. 被护板隔开的区域要涂上不同的颜色,比如上图就应该涂上5种颜色. 请编写一个程序计 ...

  2. Greedy:Paint Color(AOJ 0531)

    涂颜料 题目大意:在一个1000000*1000000的矩阵中放入几块木板,问你这些木板把矩阵划分成了几个区域?输入会给左下角和右上角的坐标,输入W==0且H==0结束. 这一题是书上的作业题,书上有 ...

  3. AOJ 0531:Paint Color(二维离散+imos)

    [题目链接] http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=0531 [题目大意] 给出一张图,和一些矩形障碍物,求该图没被障碍物覆 ...

  4. nyoj_600:花儿朵朵(树状数组+坐标离散化)

    http://acm.nyist.net/JudgeOnline/problem.php?pid=600 只附代码好了 #include<bits/stdc++.h> using name ...

  5. 【坐标离散化】AOJ0531- Paint Color

    日文题……一开始被题目骗了以为真的要写文件? 题目大意&&解答戳:❀ #include<iostream> #include<cstdio> #include& ...

  6. hihoCoder#1079(线段树+坐标离散化)

    时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho在回国之后,重新过起了朝7晚5的学生生活,当然了,他们还是在一直学习着各种算法~ 这天小Hi和小Ho所在的学 ...

  7. Atlantis(坐标离散化)

    http://poj.org/problem?id=1151 题意:给出矩形的左上角坐标和右下角坐标(坐标的y轴是向下的),求出矩形面积的并.. 今天好困啊..迷迷糊糊的听会神给讲了讲,敲完之后调试了 ...

  8. nyoj 600:花儿朵朵(树状数组+坐标离散化)

    http://acm.nyist.net/JudgeOnline/problem.php?pid=600 只附代码好了 #include<bits/stdc++.h> using name ...

  9. HDU 1542 Atlantis(线段树扫描线+离散化求面积的并)

    Atlantis Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

随机推荐

  1. python学习(五)--打印错误信息

    from urllib import request #打印错误信息 except Exceptionlist = [ "http://www.baidu11.com/", &qu ...

  2. Django组件——forms组件

    一.校验字段功能 通过注册用户这个实例来学习校验字段功能. 1.模型:models.py from django.db import models # Create your models here. ...

  3. HTML表格相关元素

    <table> 标签定义 HTML 表格.简单的 HTML 表格由 table 元素以及一个或多个 tr.th 或 td 元素组成.tr 元素定义表格行,th 元素定义表头,td 元素定义 ...

  4. 嵌入式开发 MCU

    From: http://www.infoq.com/cn/articles/intelligent-embedded-os-Internet-of-things-and-robots 嵌入式开发是一 ...

  5. myeclipse 2014 闪退问题解决

    1.删掉Workspace下面的  \.metadata\.plugins\org.eclipse.core.resources一整个文件夹 2.删掉Workspace 下面的 \.metadata\ ...

  6. 慧都启动“正版IDE联合超值推广计划

    越来越多的中国软件企业为盗版所害而蒙受巨大损失,正版化意识逐渐兴起.IDE(集成开发环境)是软件开发.编写代码必备工具,而正版IDE更具有运行更稳定.编码更安全.保障更加完善等特点,逾为中国软件行业企 ...

  7. Android学习——ViewPager的使用(二)

    这一节介绍使用FragmentPagerAdapter适配器,来加载Fragment对象. 数据源 加载Fragment对象时,数据源自然来自Fragment,与View类似,依旧使用List来存放数 ...

  8. 【Leetcode】【Medium】Single Number II

    Given an array of integers, every element appears three times except for one. Find that single one. ...

  9. [EffectiveC++]item31:将文件间的编译依存关系降至最低

    P143:“声明的依赖性"替换“定义的依存性”

  10. C4C Cloud Application Studio做ABSL开发的一些性能方面的最佳实践

    Stefan Hagen在博文SAP Cloud Application Studio Performance Best Practices里介绍了在C4C里使用Cloud Application S ...