ACM-ICPC 2018 徐州赛区网络预赛-G Trace
程序员文章站
2022-03-13 17:00:18
...
(有任何问题欢迎留言或私聊 && 欢迎交流讨论哦
Catalog
Problem:Portal传送门
原题目描述在最下面。
我理解的题意大概是:有次涨潮和退潮,每次的范围是个的矩形,求n次涨退潮后,潮水痕迹的长度。
不存在此
Solution:
每次潮水可能会冲刷掉之前的潮水的一部分痕迹,但是它又不会完全冲刷。
考虑从最后一次潮水开始往前算贡献,分x,y方向计算。
假设此次潮水的范围是,找出大于等于的最大,则方向的新增痕迹长度为,方向同理。
这样问题就转化为一个求区间最值的问题了,线段树秒。
AC_Code:
#include<bits/stdc++.h>
#define lson rt<<1
#define rson rt<<1|1
using namespace std;
typedef long long LL;
typedef unsigned long long uLL;
const int mod = 1e9+7;
const int MXN = 1e6 + 7;
int n;
int sumx[MXN<<2], sumy[MXN<<2];
int ar[MXN], br[MXN], le[MXN], ri[MXN];
void update(int op,int p,int c,int l,int r,int rt){
if(l == r){
if(op == 1) sumx[rt] = max(c,sumx[rt]);
else sumy[rt] = max(c,sumy[rt]);
return;
}
int mid = (l+r)>>1;
if(p<=mid)update(op,p,c,l,mid,lson);
else update(op,p,c,mid+1,r,rson);
if(op == 1)sumx[rt] = max(sumx[lson], sumx[rson]);
else sumy[rt] = max(sumy[lson], sumy[rson]);
}
int query(int op,int L,int R,int l,int r,int rt){
if(L<=l&&r<=R){
if(op == 1) return sumx[rt];
else return sumy[rt];
}
int mid = (l+r)>>1;
if(L>mid)return query(op,L,R,mid+1,r,rson);
else if(R<=mid)return query(op,L,R,l,mid,lson);
else {
return max(query(op,L,mid,l,mid,lson),query(op,mid+1,R,mid+1,r,rson));
}
}
int main(int argc, char const *argv[]){
scanf("%d", &n);
int k = 0;
for(int i = 1; i <= n; ++i){
scanf("%d%d", &le[i], &ri[i]);
ar[k++] = le[i];
ar[k++] = ri[i];
}
sort(ar, ar + k);
k = unique(ar, ar + k) - ar;
memset(sumx, 0, sizeof(sumx));
memset(sumy, 0, sizeof(sumy));
LL ans = 0;
for(int i = n; i >= 1; --i){
int a = le[i], b = ri[i];
le[i] = lower_bound(ar, ar + k, le[i]) - ar + 1;
ri[i] = lower_bound(ar, ar + k, ri[i]) - ar + 1;
int my = query(1, le[i], k, 1, k, 1);//找出大于xi的最大Y
ans += b - my;
int mx = query(2, ri[i], k, 1, k, 1);//找出大于yi的最大X
ans += a - mx;
//printf("%d %d\n", mx, my);
update(1, le[i], ar[ri[i]-1], 1, k, 1);//更新此xi下的yi
update(2, ri[i], ar[le[i]-1], 1, k, 1);
}
printf("%lld\n", ans);
return 0;
}
Problem Description:
推荐阅读
-
ACM-ICPC 2018 徐州赛区网络预赛 H - Ryuji doesn't want to study
-
ACM-ICPC 2018 徐州赛区网络预赛 H. Ryuji doesn't want to study(线段树区间求和)
-
ACM-ICPC 2018 徐州赛区网络预赛 H. Ryuji doesn't want to study—— 树状数组
-
ACM-ICPC 2018 徐州赛区网络预赛 H Ryuji doesn't want to study(线段树 两种做法)
-
【ACM-ICPC 2018 徐州赛区网络预赛】H题 Features Track ---- 树状数组
-
ACM-ICPC 2018 徐州赛区网络预赛 G. Trace (线段树维护)
-
计蒜客 Trace(2018 ICPC亚洲区域赛网络赛 徐州 G)(线段树)
-
ACM-ICPC 2018 徐州赛区网络预赛 Trace
-
Trace-----ACM-ICPC 2018 徐州赛区网络预赛
-
ACM-ICPC 2018 沈阳赛区网络预赛 F题 Fantastic Graph