\(>Codeforces \space 555 C. Case of Chocolate<\)

题目大意 : 有一块 \(n \times n\) 的倒三角的巧克力,有一个人要吃 \(q\) 次,每一次从一个在对角线上的点出发,向左或者向上吃若干块,直到吃到已经被吃掉的格子为止,对于每一次吃巧克力的操作,输出这一次被吃掉了多少巧克力。(文字表达不够清晰,可以配合图片理解)

\(1 ≤ n ≤ 10^9\ 1 ≤ q ≤ 2 \times 10^5\)

解题思路 :

询问可以转化为找到某一行或一列第一个被吃掉的位置,那么可以对于每一次修改,用数据结构维护这个东西

离散化后,维护每一行/列被吃掉的编号最大的格子,问题转化为了一个单点询问,区间修改的问题

可以对于行和列各建一棵线段树,对于吃掉行就修改列的线段树,对于吃掉列就修改行的线段树

对于所有询问操作就直接查对应点的答案

对于修改部分,以吃第 \(x\) 行为例,设查询到当前行被吃掉的列编号最大的的编号为 \(y\)

那么对于第 \(y + 1\) 到第 \(n - x + 1\) 列都要对 \(x\) 取 \(max\) 直接区间修改列的线段树即可, 吃列的操作同理

/*program by mangoyang*/
#include<bits/stdc++.h>
#define inf (0x7f7f7f7f)
#define Max(a, b) ((a) > (b) ? (a) : (b))
#define Min(a, b) ((a) < (b) ? (a) : (b))
typedef long long ll;
using namespace std;
template <class T>
inline void read(T &x){
int f = 0, ch = 0; x = 0;
for(; !isdigit(ch); ch = getchar()) if(ch == '-') f = 1;
for(; isdigit(ch); ch = getchar()) x = x * 10 + ch - 48;
if(f) x = -x;
}
#define lson (u << 1)
#define rson (u << 1 | 1)
#define int ll
#define N (600005)
char t[10];
map<int, int> mp[3];
int s[N], xx[N], yy[N], op[N], ff[N], gg[N], n, q, col;
struct Point{ int x, op, id; } X[N], Y[N];
inline bool cmp(Point A, Point B){ return A.x < B.x; }
struct SegmentTree{
int tag[N<<2], mx[N<<2];
inline void pushdown(int u){
if(!tag[u]) return;
mx[lson] = Max(mx[lson], tag[u]);
mx[rson] = Max(mx[rson], tag[u]);
tag[lson] = Max(tag[lson], tag[u]);
tag[rson] = Max(tag[rson], tag[u]), tag[u] = 0;
}
inline void change(int u, int l, int r, int L, int R, int v){
if(l >= L && r <= R){
mx[u] = Max(mx[u], v), tag[u] = Max(tag[u], v); return;
}
int mid = l + r >> 1; pushdown(u);
if(L <= mid) change(lson, l, mid, L, R, v);
if(mid < R) change(rson, mid + 1, r, L, R, v);
mx[u] = Max(mx[lson], mx[rson]);
}
inline int query(int u, int l, int r, int pos){
if(l == r) return mx[u];
int mid = l + r >> 1; pushdown(u);
if(pos <= mid) return query(lson, l, mid, pos);
else return query(rson, mid + 1, r, pos);
}
}R, C;
inline void calcX(int x){
xx[X[x].id] = col, op[X[x].id] = X[x].op, ff[col] = X[x].x;
}
inline void calcY(int x){
yy[Y[x].id] = col, op[Y[x].id] = Y[x].op, gg[col] = Y[x].x;
}
main(){
read(n), read(q);
for(int i = 1, x, y; i <= q; i++){
read(x), read(y), scanf("%s", t);
if(t[0] == 'U') X[i] = (Point){x, 1, i}, Y[i] = (Point){y, 1, i};
if(t[0] == 'L') X[i] = (Point){x, 2, i}, Y[i] = (Point){y, 2, i};
}
sort(X + 1, X + q + 1, cmp), ++col, calcX(1);
for(int i = 2; i <= q; i++){ if(X[i].x > X[i-1].x) ++col; calcX(i); }
int m = col; col = 0;
sort(Y + 1, Y + q + 1, cmp), ++col, calcY(1);
for(int i = 2; i <= q; i++){ if(Y[i].x > Y[i-1].x) ++col; calcY(i); }
m = max(m, col) + 100000;
for(int i = 1; i <= q; i++){
if(op[i] == 1){
if(mp[1][xx[i]]){ puts("0"); continue; }
int ls = R.query(1, 1, m, xx[i]); mp[1][xx[i]] = 1;
C.change(1, 1, m, ls + 1, yy[i], xx[i]);
printf("%lld\n", n - ff[xx[i]] + 1 - gg[ls]);
}
if(op[i] == 2){
if(mp[2][yy[i]]){ puts("0"); continue; }
int ls = C.query(1, 1, m, yy[i]); mp[2][yy[i]] = 1;
R.change(1, 1, m, ls + 1, xx[i], yy[i]);
printf("%lld\n", n - gg[yy[i]] + 1 - ff[ls]);
}
}
return 0;
}

Codeforces 555 C. Case of Chocolate的更多相关文章

  1. Codeforces 555 B. Case of Fugitive

    \(>Codeforces \space 555 B. Case of Fugitive<\) 题目大意 : 有 \(n\) 个岛屿有序排列在一条线上,第 \(i\) 个岛屿的左端点为 \ ...

  2. Codeforces Round #310 (Div. 1) C. Case of Chocolate set

    C. Case of Chocolate Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/555/ ...

  3. Codeforces 555C Case of Chocolate 其他

    原文链接https://www.cnblogs.com/zhouzhendong/p/9272797.html 题目传送门 - CF555C 题意 给定一个 $n\times n(n\leq 10^9 ...

  4. codeforces 555c// Case of Chocolate// Codeforces Round #310(Div. 1)

    题意:直角边为n的网格巧克力,一格为一块,选择斜边上一点,从左或上吃,直到吃到空气,称为一次操作.给出几个操作,问各能吃几块.如果x是当前要吃的横坐标,在已经吃过的中找x1>=x的第一个x1,即 ...

  5. Codeforces Round #310 (Div. 1) C. Case of Chocolate (线段树)

    题目地址:传送门 这题尽管是DIV1的C. . 可是挺简单的. .仅仅要用线段树分别维护一下横着和竖着的值就能够了,先离散化再维护. 每次查找最大的最小值<=tmp的点,能够直接在线段树里搜,也 ...

  6. 【35.37%】【codeforces 556C】Case of Matryoshkas

    time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

  7. 【66.47%】【codeforces 556B】Case of Fake Numbers

    time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

  8. Codeforces 556A:Case of the Zeros and Ones

    A. Case of the Zeros and Ones time limit per test 1 second memory limit per test 256 megabytes input ...

  9. codeforces 678C C. Joty and Chocolate(水题)

    题目链接: C. Joty and Chocolate time limit per test 1 second memory limit per test 256 megabytes input s ...

随机推荐

  1. 基于 Docker 的 Zabbix 微服务系统

    zabbix 官网提供一个镜像 [ zabbix-appliance ], 可以直接拉起一个 zabbix-server. 但是数据库无法分离出来. 本实践使用 zabbix 官方提供的 Docker ...

  2. 边缘检测:Canny算子,Sobel算子,Laplace算子

    1.canny算子 Canny边缘检测算子是John F.Canny于 1986 年开发出来的一个多级边缘检测算法.更为重要的是 Canny 创立了边缘检测计算理论(Computational the ...

  3. [NOIP2011]刷水

    前几天做了NOIP2011的题,感觉不是那么难. 这边先做了两天的前两题,T3还没打. D1T1:顺次读入,分别判断是否覆盖即可,照例大水: #include<cstdio> ],b[], ...

  4. TCP之Nagle算法&&延迟ACK

    1. Nagle算法: 是为了减少广域网的小分组数目,从而减小网络拥塞的出现: 该算法要求一个tcp连接上最多只能有一个未被确认的未完成的小分组,在该分组ack到达之前不能发送其他的小分组,tcp需要 ...

  5. gpio子系统和pinctrl子系统(下)

    情景分析 打算从两个角度来情景分析,先从bsp驱动工程师的角度,然后是驱动工程师的角度,下面以三星s3c6410 Pinctrl-samsung.c为例看看pinctrl输入参数的初始化过程(最开始的 ...

  6. HTML综合实例【月福首页】

    1. 首页的布局结构 2. 排版的准备工作 网站的素材:与当前网页放在一起. 创建一个html文件,来进行排版. 网页的背景色 确定主页的宽度:778px 3. HTML注释 <!-- 注释内容 ...

  7. PhysX SDK

    PhysX SDK https://developer.nvidia.com/physx-sdk NVIDIA PhysX SDK Downloads http://www.nvidia.cn/obj ...

  8. 003 CopyOnWriteArrayList原理

    聊聊并发-Java中的Copy-On-Write容器 Copy-On-Write简称COW,是一种用于程序设计中的优化策略.其基本思路是,从一开始大家都在共享同一个内容,当某个人想要修改这个内容的时候 ...

  9. 给自己立一个flag

    工作理念:做完!做对!做好!做优! 1.请教问题方面 遇到问题先自己想办法解决(限定时长为30分钟). 请教问题的时候,明确:“问题是什么,为什么错在那里,结果是什么” 2.博客 一周两篇左右:对工作 ...

  10. .net页面实时预览图片

    <script type="text/javascript"> //获取上传图片的本地路径 function getPath(obj){ if(obj) { if(na ...