题意略去。

考虑给定的R对pair(A, B)。

即A能看见B,这意味着B不比A低,并且区间内部的所有元素的高度严格小于A的高度。

我们规定区间的方向:若A > B,为反方向,反之称为正方向。

容易发现,区间在同一方向上不交叉,即要么相离,要么相互包含。

在相反反方向上,若两区间不相互包含,必定是有且仅有一个公共区间端点。

首先将所有idx上的高度默认设置为H。

对于相离的区间,他们之间的计算是独立的。

考虑相互包含的区间,先考虑范围最大的那个区间,处理之间闭区间[A,B]上的高度是相同的,满足此条件只需令(A,B)区间内元素自减一。

递归考虑其包含的区间,显然这样的做法是最优的且合法的。

实际上这与考虑区间的次序无关。

即每得到一个区间,对开区间内的元素减一即可。

可以用线段树来做区间的修改操作。

http://poj.org/problem?id=3263

 #include <cstdio>
#include <cstring>
#include <algorithm>
#include <set>
using namespace std;
const int maxn = 1e4 + ;
set< pair<int, int> > S;
struct Seg{
int l, r, h;
int lazy;
}seg[maxn << ];
int n, m, I, H; void build(int u, int l, int r){
seg[u].l = l;
seg[u].r = r;
seg[u].lazy = ;
seg[u].h = H;
if(r - l < ) return;
int mid = (l + r) >> ;
build(u << , l, mid);
build(u << | , mid, r);
} void push_down(int u){
if(seg[u].lazy > && seg[u].r - seg[u].l > ){
int mid = (seg[u].l + seg[u].r) >> ;
seg[u << ].lazy += seg[u].lazy;
seg[u << | ].lazy += seg[u].lazy;
seg[u << ].h -= seg[u].lazy;
seg[u << | ].h -= seg[u].lazy;
seg[u].lazy = ;
}
} void update(int u, int l, int r, int L, int R){
if(R - L < ) return;
if(L == l && r == R){
seg[u].lazy++;
seg[u].h--;
return;
}
push_down(u);
int mid = (l + r) >> ;
if(R <= mid) update(u << , l, mid, L, R);
else if(L >= mid) update(u << | , mid, r, L, R);
else{
update(u << , l, mid, L, mid);
update(u << | , mid, r, mid, R);
}
} void query(int u, int l, int r){
if(r - l == ){
printf("%d\n", seg[u].h);
return;
}
push_down(u);
int mid = (l + r) >> ;
query(u << , l, mid);
query(u << | , mid, r);
} int main(){
while(~scanf("%d%d%d%d", &n, &I, &H, &m)){
build(, , n + );
S.clear();
for(int i = , u, v; i < m; i++){
scanf("%d%d", &u, &v);
if(u == v || S.find(make_pair(u, v)) != S.end()) continue;
S.insert(make_pair(u, v));
if(u > v) swap(u, v);
update(, , n + , u + , v);
}
query(, , n + );
}
return ;
}

poj3263 Tallest Cow的更多相关文章

  1. POJ3263 Tallest Cow 差分

    题目描述 FJ's N (1 ≤ N ≤ 10,000) cows conveniently indexed 1..N are standing in a line. Each cow has a p ...

  2. BZOJ1635: [Usaco2007 Jan]Tallest Cow 最高的牛

    1635: [Usaco2007 Jan]Tallest Cow 最高的牛 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 346  Solved: 184 ...

  3. BZOJ 1635: [Usaco2007 Jan]Tallest Cow 最高的牛

    题目 1635: [Usaco2007 Jan]Tallest Cow 最高的牛 Time Limit: 5 Sec  Memory Limit: 64 MB Description FJ's N ( ...

  4. 1635: [Usaco2007 Jan]Tallest Cow 最高的牛

    1635: [Usaco2007 Jan]Tallest Cow 最高的牛 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 383  Solved: 211 ...

  5. Tallest Cow POJ - 3263 (区间点修改)

    FJ's N (1 ≤ N ≤ 10,000) cows conveniently indexed 1..N are standing in a line. Each cow has a positi ...

  6. 洛谷P2879 [USACO07JAN]区间统计Tallest Cow

    To 洛谷.2879 区间统计 题目描述 FJ's N (1 ≤ N ≤ 10,000) cows conveniently indexed 1..N are standing in a line. ...

  7. bzoj1635 / P2879 [USACO07JAN]区间统计Tallest Cow

    P2879 [USACO07JAN]区间统计Tallest Cow 差分 对于每个限制$(l,r)$,我们建立一个差分数组$a[i]$ 使$a[l+1]--,a[r]++$,表示$(l,r)$区间内的 ...

  8. 【BZOJ】1635: [Usaco2007 Jan]Tallest Cow 最高的牛(差分序列)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1635 差分序列是个好东西啊....很多地方都用了啊,,, 线性的进行区间操作orz 有题可知 h[a ...

  9. bzoj 1635: [Usaco2007 Jan]Tallest Cow 最高的牛——差分

    Description FJ's N (1 <= N <= 10,000) cows conveniently indexed 1..N are standing in a line. E ...

随机推荐

  1. max-min fairness 最大最小公平算法

    我们经常面临给一组用户划分稀有资源的问题,他们都享有等价的权利来获取资源,但是其中一些用户实际上只需要比其他用户少的资源.那么我们如何来分配资源呢?一种在实际中广泛使用的分享技术称作“最大最小公平分享 ...

  2. 脚本:SQLServer 2008 生成某数据库中的所有索引创建脚本

    --1. get all indexes from current db, place in temp table select schemaName = s.name, tablename = ob ...

  3. devexpress13学习系列(一)PDFViewer(1)

    使用这个组件,可以直接在winform里显示pdf文档,不需要另外装软件了. 有这么几个重要的属性: 1.DocumentFilePath:要读取的PDF的文件和路径. 2.CurrentPageNu ...

  4. bootstrap datetimepicker时间日期控件

    github地址:https://github.com/smalot/bootstrap-datetimepicker Both Date and Time picker widget based o ...

  5. Winform 控件

    ※控件在视图工具箱里面找,找到之后双击即可添加进来,也可以点住拖进来 ※每个工具,控件,窗体都有一个name,相当于id,用来标识该对象的名称,name值不允许重复 控件: 1.Label -- 文本 ...

  6. Sping中的事务配置

    关于Spring的事务配置,主要的配置文件如下(使用了C3P0连接池): <?xml version="1.0" encoding="UTF-8"?> ...

  7. FRM-92101解决办法

    /u02/UAT/inst/apps/UAT_newerp3/logs/ora/10.1.3/opmn/forms_default_group_1/ http://blog.csdn.net/orth ...

  8. 《OpenGL游戏编程》第9章-PlanarShadow关键代码注释

    阴影这块确实是难点.说到阴影就必须提到投影矩阵.模板值为1和2时分别渲染.说来话长,仅仅放上代码,供日后查阅. /** 渲染墙面和阴影 */ void CPlanarShadow::Render() ...

  9. js编写规范

    JavaScript编码规范 Bug----33条 1. 不要使用’==’和’!=’,使用’===’和’!==’替代 等级:Major 原因:==和!=在判断值相等前会判断类型是否相等.这容易因为类型 ...

  10. Linux下串口编程【转】

    本文转载自:http://blog.csdn.net/w282529350/article/details/7378388 /************声明:本人只是见到这篇文章对我帮助很大才转载的,但 ...