【IOI 1998】 Picture
【题目链接】
【算法】
线段树扫描线求周长并
【代码】
- #include <algorithm>
- #include <bitset>
- #include <cctype>
- #include <cerrno>
- #include <clocale>
- #include <cmath>
- #include <complex>
- #include <cstdio>
- #include <cstdlib>
- #include <cstring>
- #include <ctime>
- #include <deque>
- #include <exception>
- #include <fstream>
- #include <functional>
- #include <limits>
- #include <list>
- #include <map>
- #include <iomanip>
- #include <ios>
- #include <iosfwd>
- #include <iostream>
- #include <istream>
- #include <ostream>
- #include <queue>
- #include <set>
- #include <sstream>
- #include <stdexcept>
- #include <streambuf>
- #include <string>
- #include <utility>
- #include <vector>
- #include <cwchar>
- #include <cwctype>
- #include <stack>
- #include <limits.h>
- using namespace std;
- #define MAXN 5010
- int i,L,R,l1,l2,ans,last,n,xa,xb,ya,yb;
- int x[MAXN*];
- struct info {
- int l,r,h,opt;
- } y[MAXN*];
- struct Node {
- int l,r,sum,cnt,c;
- bool lc,rc;
- } Tree[MAXN*];
- bool cmp(info a,info b) { return a.h > b.h; }
- template <typename T> inline void read(T &x) {
- int f = ; x = ;
- char c = getchar();
- for (; !isdigit(c); c = getchar()) { if (c == '-') f = -f; }
- for (; isdigit(c); c = getchar()) x = (x << ) + (x << ) + c - '';
- x *= f;
- }
- template <typename T> inline void write(T x) {
- if (x < ) { putchar('-'); x = -x; }
- if (x > ) write(x/);
- putchar(x%+'');
- }
- template <typename T> inline void writeln(T x) {
- write(x);
- puts("");
- }
- inline void build(int index,int l,int r) {
- int mid;
- Tree[index].l = l;
- Tree[index].r = r;
- Tree[index].c = Tree[index].sum = Tree[index].cnt = ;
- Tree[index].lc = Tree[index].rc = false;
- if (l == r) return;
- mid = (l + r) >> ;
- build(index<<,l,mid);
- build(index<<|,mid+,r);
- }
- inline void push_up(int index) {
- if (Tree[index].c > ) {
- Tree[index].sum = x[Tree[index].r+] - x[Tree[index].l];
- Tree[index].cnt = ;
- Tree[index].lc = Tree[index].rc = true;
- } else if (Tree[index].l == Tree[index].r) {
- Tree[index].sum = Tree[index].cnt = ;
- Tree[index].lc = Tree[index].rc = false;
- } else {
- Tree[index].lc = Tree[index<<].lc;
- Tree[index].rc = Tree[index<<|].rc;
- Tree[index].sum = Tree[index<<].sum + Tree[index<<|].sum;
- Tree[index].cnt = Tree[index<<].cnt + Tree[index<<|].cnt;
- if (Tree[index<<].rc && Tree[index<<|].lc) Tree[index].cnt--;
- }
- }
- inline void update(int index,int l,int r,int val) {
- int mid;
- if (Tree[index].l == l && Tree[index].r == r) {
- Tree[index].c += val;
- push_up(index);
- return;
- }
- mid = (Tree[index].l + Tree[index].r) >> ;
- if (mid >= r) update(index<<,l,r,val);
- else if (mid + <= l) update(index<<|,l,r,val);
- else {
- update(index<<,l,mid,val);
- update(index<<|,mid+,r,val);
- }
- push_up(index);
- }
- int main() {
- scanf("%d",&n);
- l1 = l2 = ;
- for (i = ; i <= n; i++) {
- read(xa); read(ya); read(xb); read(yb);
- x[++l1] = xa;
- x[++l1] = xb;
- y[++l2] = (info){xa,xb,ya,-};
- y[++l2] = (info){xa,xb,yb,};
- }
- l1 = unique(x+,x+l1+) - x;
- sort(x+,x+l1+);
- build(,,l1-);
- sort(y+,y+l2+,cmp);
- ans = last = ;
- for (i = ; i < l2; i++) {
- L = lower_bound(x+,x+l1+,y[i].l) - x;
- R = lower_bound(x+,x+l1+,y[i].r) - x - ;
- update(,L,R,y[i].opt);
- ans += Tree[].cnt * * (y[i].h - y[i+].h);
- ans += abs(Tree[].sum - last);
- last = Tree[].sum;
- }
- L = lower_bound(x+,x+l1+,y[l2].l) - x;
- R = lower_bound(x+,x+l1+,y[l2].r) - x - ;
- update(,L,R,y[l2].opt);
- ans += abs(Tree[].sum - last);
- writeln(ans);
- return ;
- }
【IOI 1998】 Picture的更多相关文章
- 【HDU 1828】 Picture (矩阵周长并,线段树,扫描法)
[题目] Picture Problem Description A number of rectangular posters, photographs and other pictures of ...
- 【IOI 1996】 Network of Schools
[题目链接] 点击打开链接 [算法] 对于第一问,将这个图缩点,输出出度为零的点的个数 对于第二问,同样将这个图缩点,输出入度为零.出度为零的点的个数的最大值 [代码] #include <al ...
- 【IOI 1994】 The Buses
[题目链接] http://poj.org/problem?id=1167 [算法] 深度优先搜索 + 迭代加深 [代码] #include <algorithm> #include &l ...
- 【IOI 2011】Race
[题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=2599 [算法] 点分治 [代码] #include<bits/stdc++.h ...
- 【49.23%】【hdu 1828】Picture
Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s) ...
- 【BZOJ 1998】 1998: [Hnoi2010]Fsk物品调度(双向链表+并查集+置换)
1998: [Hnoi2010]Fsk物品调度 Description 现在找工作不容易,Lostmonkey费了好大劲才得到fsk公司基层流水线操作员的职位.流水线上有n个位置,从0到n-1依次编号 ...
- 【IOI 2018】Werewolf 狼人
虽然作为IOI的Day1T3,但其实不是一道很难的题,或者说这道题其实比较套路吧. 接下来讲解一下这个题的做法: 如果你做过NOI 2018的Day1T1,并且看懂了题面,那你很快就会联想到这道题,因 ...
- 【IOI 2018】Combo 组合动作(模拟,小技巧)
题目链接 IOI的签到题感觉比NOI的签到题要简单啊,至少NOI同步赛我没有签到成功…… 其实这个题还是挺妙妙的,如果能够从题目出发,利用好限制,应该是可以想到的做法的. 接下来开始讲解具体的做法: ...
- 【Vijos 1998】【SDOI 2016】平凡的骰子
https://vijos.org/p/1998 三维计算几何. 需要混合积求四面体体积: 四面体剖分后合并带权重心求总重心: 四面体重心的横纵坐标是四个顶点的横纵坐标的平均数: 三维差积求平面的法向 ...
随机推荐
- P1027 car的旅行路线
car的旅行路线 洛谷链接 这个题关键就是 如何把每个点表示出来,其实求出四个点的坐标后,只需要把这些点连接起来,用一遍folyed求出最短路径就好了. 代码: #include<cmath&g ...
- git push ‘No refs in common and none specified’doing nothing问题解决
git push ‘No refs in common and none specified’doing nothing问题解决 输入git push origin master即可解决问题
- UltraEdit-14.10.0.1024版本语法着色配置
用了UltraEdit有段时间了,一直没做语法着色,当做普通文本编辑器使用,这也太委屈这个“神器”了. 今天就让它物尽其用吧.体验一把UltraEdit的语法高亮功能. 参考:http://www.1 ...
- 45个android实例源码分享
分享45个android实例源码,很好很强大 http://www.apkbus.com/android-20978-1-1.html andriod闹钟源代码 http://www.apkbus.c ...
- 洛谷P3094 [USACO13DEC]假期计划Vacation Planning
题目描述 有N(1 <= N <= 200)个农场,用1..N编号.航空公司计划在农场间建立航线.对于任意一条航线,选择农场1..K中的农场作为枢纽(1 <= K <= 100 ...
- type和metaclass元类
元类type 1. 创建类的两种方式 (都是由type元类创建) 方式一: class Foo(object): # 默认metaclass = type, 当前类, 由type类创建 a = 'aa ...
- hdu - 5128 The E-pang Palace(枚举+计算几何)
http://acm.hdu.edu.cn/showproblem.php?pid=5128 给出n个点,求n个点组成两个矩形的最大面积. 矩形必须平行x轴,并且不能相交,但是小矩形在大矩形内部是可以 ...
- 关于Chrome谷歌浏览器开发者工具网络Network中返回无数据的问题
1.如图所示,对于有些js文件,响应中无返回数据,Failed to load response data,当然本来是应该有数据,你用火狐浏览器看,就是有的,或者直接在浏览器地址栏里输入url,也可以 ...
- 海量数据处理面试题学习zz
来吧骚年,看看海量数据处理方面的面试题吧. 原文:(Link, 其实引自这里 Link, 而这个又是 Link 的总结) 另外还有一个系列,挺好的:http://blog.csdn.net/v_jul ...
- centos Crontab
minute hour day month week command 顺序:分 时 日 月 周 命令 第1列分钟1-59第2列小时1-23(0表示子夜)第3列日1-31第4 ...