PICTURE

题目描述

N(N<5000) 张矩形的海报,照片和其他同样形状的图片贴在墙上。它们的边都是垂直的或水平的。每个矩形可以部分或者全部覆盖其他矩形。所有的矩形组成的集合的轮廓称为周长。写一个程序计算周长。

图 1 是一个有 7 个矩形的例子:

图 1.一个 7 个矩形的集合对应的轮廓为图 2 所示的所有线段的集合:

图 2. 矩形集合的轮廓

所有矩形的顶点坐标均为整数。所有的坐标都在 [-10000,10000] 的范围内,并且任何一个矩形面积都为整数。结果的值可能需要 32 位有符号整数表示。

输入

第1行: N,张贴在墙上的矩形的数目。 第 2..N+1行 接下来的N行中,每行都有两个点的坐标,分别是矩形的左下角坐标和右上角坐标。每一个坐标由 X 坐标和 Y 坐标组成。

输出

只有一行,为一个非负整数,表示输入数据中所有矩形集合的轮廓长度。

样例输入

7
-15 0 5 10
-5 8 20 25
15 -4 24 14
0 -6 16 4
2 15 10 22
30 10 36 20
34 0 40 16

样例输出

228

自己写(chao)的,并没有用线段树维护,加了快读8ms
 #include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std; struct data {
int lx, rx;
int ly, ry;
}; const int maxn = , maxx = ;
int n;
data a[maxn + ];
int level[maxx + ]; bool cmp_x(data x, data y) {
return x.lx < y.lx;
} bool cmp_y(data x, data y) {
return x.ly < y.ly;
} int in() {
int f = , p = ;
char c;
while (c < '' || c > '') {
c = getchar();
if (c == '-') {
f = -;
}
}
while (c >= '' && c <= '') {
p = p * + c - '';
c = getchar();
}
p *= f;
return p;
} void init() {
n = in();
for (int i = ; i <= n; i++) {
a[i].lx = in();
a[i].ly = in();
a[i].rx = in();
a[i].ry = in();
a[i].lx += ;
a[i].ly += ;
a[i].rx += ;
a[i].ry += ;
}
} int solve_x() {
memset(level, -, sizeof(level));
int ans = ;
sort(a + , a + + n, cmp_x);
for (int i = ; i <= n; i++) {
for (int j = a[i].ly; j < a[i].ry; j++) {
if (level[j] < a[i].lx) {
ans += ;
}
if (level[j] < a[i].rx) {
level[j] = a[i].rx;
}
}
}
return ans;
} int solve_y() {
memset(level, -, sizeof(level));
int ans = ;
sort(a + , a + + n, cmp_y);
for (int i = ; i <= n; i++) {
for (int j = a[i].lx; j < a[i].rx; j++) {
if (level[j] < a[i].ly) {
ans += ;
}
if (level[j] < a[i].ry) {
level[j] = a[i].ry;
}
}
}
return ans;
} int main() {
init();
printf("%d\n", solve_x() + solve_y());
return ;
}

下面是学长的QAQQ用了线段树维护

 #include<cstdio>
#include<algorithm>
#define MN 10000
#define MX 20000
#define L (k << 1)
#define R ((k << 1) + 1)
using namespace std; struct work{ //扫描线
int x, l, r, p;
}x[MN + ], y[MN + ]; bool cmp(work a, work b){
return a.x == b.x ? a.p > b.p : a.x < b.x;
} struct data{
int x, s;
}; data operator + (data a, data b){
if (a.x == b.x) {
return (data) {
a.x, a.s + b.s
};
}
return a.x < b.x ? a : b;
} struct node{
int l, r, mk;
data x;
}t[MX * + ]; inline void up (int k){
t[k].x = t[L].x + t[R].x;
} inline void add(int k, int x){
t[k].x.x += x;
t[k].mk += x;
} inline void down(int k){
if (t[k].mk) {
add(L, t[k].mk);
add(R, t[k].mk);
t[k].mk = ;
}
} void build(int k, int l, int r) {
t[k].l = l;
t[k].r = r;
if (l == r) {
t[k].x.s = ;
return;
}
int mid = l + r >> ;
build(L, l, mid);
build(R, mid + , r);
up(k);
} void renew(int k, int l, int r, int x) {
if (t[k].l == l && t[k].r == r) {
add(k, x);
return;
}
down(k);
int mid = t[k].l + t[k].r >> ;
if (r <= mid) {
renew(L, l, r, x);
}
else if (l > mid) {
renew(R, l, r, x);
}
else {
renew(L, l, mid, x);
renew(R, mid + , r, x);
}
up(k);
} data query(int k, int l, int r){
if (t[k].l == l && t[k].r == r) {
return t[k].x;
}
down(k);
int mid = (t[k].l + t[k].r) >> ;
if (r <= mid) {
return query(L, l, r);
}
if (l > mid) {
return query(R, l, r);
}
return query(L, l, mid) + query(R, mid + , r);
}
int n, ans;
void solve (work *x) {
for (int i = ; i < n; i++) {
if (x[i].p < ) {
renew(, x[i].l, x[i].r, -);
}
data d = query(, x[i].l, x[i].r);
if (x[i].p > ) {
renew(, x[i].l, x[i].r, );
}
ans += d.x ? : d.s;
}
} int main(){
int i, x0, y0, x1, y1;
scanf("%d", &n);
for (int i = ; i < n; ++i) {
scanf("%d%d%d%d", &x0, &y0, &x1, &y1);
x0 += MN;
y0 += MN;
x1 += MN;
y1 += MN;
x[i] = (work) {
y0, x0, x1 - ,
};
x[i + n] = (work) {
y1, x0, x1 - , -
};
y[i] = (work) {
x0, y0, y1 - ,
};
y[i + n] = (work) {
x1, y0, y1 - , -
};
}
n <<= ;
sort(x, x + n, cmp);
sort(y, y + n, cmp);
build(, , MX);
solve(x);
solve(y);
printf("%d", ans);
return ;
}
												

[线段树]picture的更多相关文章

  1. [矩形并-扫描线-线段树]Picture

    最近在补数学和几何,没啥好写的,因为已经决定每天至少写一篇了,今天随便拿个题水水. 题目大意:给你N个边平行于坐标轴的矩形,求它们并的周长.(N<=5000) 思路:这个数据范围瞎暴力就过了,但 ...

  2. hdu 1828 Picture(线段树 || 普通hash标记)

    http://acm.hdu.edu.cn/showproblem.php?pid=1828 Picture Time Limit: 6000/2000 MS (Java/Others)    Mem ...

  3. 51nod 1206 Picture 矩形周长求并 | 线段树 扫描线

    51nod 1206 Picture 矩形周长求并 | 线段树 扫描线 #include <cstdio> #include <cmath> #include <cstr ...

  4. HDU 1828 / POJ 1177 Picture --线段树求矩形周长并

    题意:给n个矩形,求矩形周长并 解法:跟求矩形面积并差不多,不过线段树节点记录的为: len: 此区间线段长度 cover: 此区间是否被整个覆盖 lmark,rmark: 此区间左右端点是否被覆盖 ...

  5. HDU 1828 / POJ 1177 Picture (线段树扫描线,求矩阵并的周长,经典题)

    做这道题之前,建议先做POJ 1151  Atlantis,经典的扫描线求矩阵的面积并 参考连接: http://www.cnblogs.com/scau20110726/archive/2013/0 ...

  6. 【IOI1998】Picture(扫描线+线段树)

    问题来源:IOI1998 D2T1 题意:就是在一个平面内给出n个矩形,叫你计算将这些矩形合并以后,新图形的周长. 例如: 上图是原本的矩形们 ---------->合并后的图形 解题思路:拿一 ...

  7. hdu 1828 Picture(线段树扫描线矩形周长并)

    线段树扫描线矩形周长并 #include <iostream> #include <cstdio> #include <algorithm> #include &l ...

  8. POJ 1177 Picture(线段树:扫描线求轮廓周长)

    题目链接:http://poj.org/problem?id=1177 题目大意:若干个矩形,求这些矩形重叠形成的图形的轮廓周长. 解题思路:这里引用一下大牛的思路:kuangbin 总体思路: 1. ...

  9. 【HDOJ1828&&POJ1177】Picture(线段树,扫描线)

    题意:给定n个矩形,求他们的并的周长 n<=5e3,abs(x[i])<=1e4 思路:From https://www.cnblogs.com/kuangbin/archive/2013 ...

随机推荐

  1. gdb 常用调试命令

    1.   file    quit 2.   frame bt 3.   finish 运行程序,直到当前函数完成返回,并打印函数返回时的堆栈地址和返回值及参数信息. until 当要退出在一个循环体 ...

  2. html5新增标签做基本布局

    结构标记 ***** 做布局 1.<header>元素 <header></header> ==> <div id="header" ...

  3. Realtime Rendering 6

    [Realtime Rendering 6] 1.Lighting computations occur in two phases: 1)light phase. used to compute t ...

  4. DNS隧道 iodns

    通过iodns这个工具也能搭建DNS隧道 iodns的优点: 对下行数据不进行编码,速度快 支持多平台 最大16个并发连接 强制密码设定 iodns创建的DNS隧道网段不能喝服务器,客户端同一网段,比 ...

  5. JMeter学习(二十八)内存溢出解决方法(转载)

    转载自 http://www.cnblogs.com/yangxia-test 使用jmeter进行压力测试时遇到一段时间后报内存溢出outfmenmory错误,导致jmeter卡死了,先尝试在jme ...

  6. day18 logging模块 sys shelve

    昨日回顾 re 正则表达式 匹配字符串 场景 例如:爬虫,密码规则验证,邮箱地址验证,手机号码 学习re主要学习的就是 那一堆特殊符号 hashlib hash是一种算法 lib表示库 该模块包含了一 ...

  7. 8个纯CSS3制作的动画应用及源码

    对于一个复杂的图形或者动画来说,之前我们的处理方式是图片叠加或者利用CSS+JavaScript的方法,然而随着CSS3标准的不断成熟,我们甚至完全可以利用CSS3来绘制一些图片和制作丰富的动画特效. ...

  8. 两条线段求交点+叉积求面积 poj 1408

    题目链接:https://vjudge.net/problem/POJ-1408 题目是叫我们求出所有四边形里最大的那个的面积. 思路:因为这里只给了我们正方形四条边上的点,所以我们要先计算横竖线段两 ...

  9. 抛弃WebService,在.NET4中用 jQuery 调用 WCF

    在我们之前的开发中,对于ajax程序,都是通过jQuery调用标记为[System.Web.Script.Services.ScriptService]的WebService,然后在WebServic ...

  10. TCL脚本语言基础介绍

    Tcl简介(一):Tcl 语法 Tcl 语法 Tcl是一种很通用的脚本语言,它几乎在所有的平台上都可以释运行,其强大的功能和简单精妙的语法会使你感到由衷的喜悦,这片文章对 Tcl有很好的描述和说明.如 ...