【CF】310 Div.1 C. Case of Chocolate
线段树的简单题目,做一个离散化,O(lgn)可以找到id。RE了一晚上,额,后来找到了原因。
/* 555C */
#include <iostream>
#include <string>
#include <map>
#include <queue>
#include <set>
#include <stack>
#include <vector>
#include <deque>
#include <algorithm>
#include <cstdio>
#include <cmath>
#include <ctime>
#include <cstring>
#include <climits>
#include <cctype>
#include <cassert>
#include <functional>
#include <iterator>
#include <iomanip>
using namespace std;
//#pragma comment(linker,"/STACK:102400000,1024000") #define sti set<int>
#define stpii set<pair<int, int> >
#define mpii map<int,int>
#define vi vector<int>
#define pii pair<int,int>
#define vpii vector<pair<int,int> >
#define rep(i, a, n) for (int i=a;i<n;++i)
#define per(i, a, n) for (int i=n-1;i>=a;--i)
#define clr clear
#define pb push_back
#define mp make_pair
#define fir first
#define sec second
#define all(x) (x).begin(),(x).end()
#define SZ(x) ((int)(x).size())
#define lson l, mid, rt<<1
#define rson mid+1, r, rt<<1|1 typedef struct {
int x, y;
char op[];
} node_t; const int maxn = 2e5+;
const int maxm = 4e5+;
node_t Q[maxn];
int rn[maxm];
int mxr[maxm<<];
int mxc[maxm<<];
int rL[maxm<<];
int cT[maxm<<];
int L, R; void build(int l, int r, int rt) {
rL[rt] = ;
cT[rt] = ;
if (l == r)
return ; int mid = (l+r)>>;
build(lson);
build(rson);
} inline void PushDownR(int rt) {
int lb = rt<<;
int rb = lb | ; if (mxr[rt]) {
rL[rt] = max(rL[rt], mxr[rt]);
mxr[lb] = max(mxr[lb], mxr[rt]);
mxr[rb] = max(mxr[rb], mxr[rt]);
mxr[rt] = ;
}
} inline void PushDownC(int rt) {
int lb = rt<<;
int rb = lb | ; if (mxc[rt]) {
cT[rt] = max(cT[rt], mxc[rt]);
mxc[lb] = max(mxc[lb], mxc[rt]);
mxc[rb] = max(mxc[rb], mxc[rt]);
mxc[rt] = ;
}
} inline void PushDown(int rt) {
int lb = rt<<;
int rb = lb | ; if (mxr[rt]) {
rL[rt] = max(rL[rt], mxr[rt]);
mxr[lb] = max(mxr[lb], mxr[rt]);
mxr[rb] = max(mxr[rb], mxr[rt]);
mxr[rt] = ;
} if (mxc[rt]) {
cT[rt] = max(cT[rt], mxc[rt]);
mxc[lb] = max(mxc[lb], mxc[rt]);
mxc[rb] = max(mxc[rb], mxc[rt]);
mxc[rt] = ;
}
} void updateR(int delta, int l, int r, int rt) {
if (L<=l && R>=r) {
mxr[rt] = max(mxr[rt], delta);
return ;
} int mid = (l+r)>>; PushDownR(rt);
if (mid >= R) {
updateR(delta, lson);
} else if (mid < L) {
updateR(delta, rson);
} else {
updateR(delta, lson);
updateR(delta, rson);
}
} void updateC(int delta, int l, int r, int rt) {
if (L<=l && R>=r) {
mxc[rt] = max(mxc[rt], delta);
return ;
} int mid = (l+r)>>; PushDownC(rt);
if (mid >= R) {
updateC(delta, lson);
} else if (mid < L) {
updateC(delta, rson);
} else {
updateC(delta, lson);
updateC(delta, rson);
}
} pii query(int l, int r, int rt) {
if (l == r) {
rL[rt] = max(rL[rt], mxr[rt]);
cT[rt] = max(cT[rt], mxc[rt]);
mxr[rt] = ;
mxc[rt] = ; pii p(rL[rt], cT[rt]);
return p;
}
int mid = (l+r)>>; PushDown(rt);
if (mid >= R) {
return query(lson);
} else {
return query(rson);
}
} int main() {
ios::sync_with_stdio(false);
#ifndef ONLINE_JUDGE
freopen("data.in", "r", stdin);
freopen("data.out", "w", stdout);
#endif int n, q;
mpii tb;
sti st; scanf("%d %d", &n, &q);
rep(i, , q) {
scanf("%d %d %s", &Q[i].y, &Q[i].x, Q[i].op);
st.insert(Q[i].x);
st.insert(Q[i].y);
}
st.insert(); int m = ;
int i, j, k; for (sti::iterator siter=st.begin(); siter!=st.end(); ++siter) {
k = *siter;
++m;
rn[m] = k;
tb[k] = m;
} int x, y, idx, idy;
int ans;
pii p; build(, m, );
rep(i, , q) {
x = Q[i].x;
y = Q[i].y;
if (Q[i].op[] == 'U') {
idy = tb[y];
L = R = idy;
p = query(, m, );
updateC(x+, , m, );
ans = x - p.sec + ;
idx = tb[x];
k = lower_bound(rn+, rn++m, p.sec) - rn;
L = k;
R = idx;
if (L <= R)
updateR(y+, , m, );
} else {
idx = tb[x];
L = R = idx;
p = query(, m, );
updateR(y+, , m, );
ans = y - p.fir + ;
idy = tb[y];
k = lower_bound(rn+, rn++m, p.fir) - rn;
L = k;
R = idy;
if (L <= R)
updateC(x+, , m, );
}
#ifndef ONLINE_JUDGE
printf("L = %d, R = %d\n", L, R);
#endif
if (ans < )
ans = ;
printf("%d\n", ans);
} #ifndef ONLINE_JUDGE
printf("time = %d.\n", (int)clock());
#endif return ;
}
【CF】310 Div.1 C. Case of Chocolate的更多相关文章
- 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/ ...
- 【CF】121 Div.1 C. Fools and Roads
题意是给定一棵树.同时,给定如下k个查询: 给出任意两点u,v,对u到v的路径所经过的边进行加计数. k个查询后,分别输出各边的计数之和. 思路利用LCA,对cnt[u]++, cnt[v]++,并对 ...
- 【CF】110 Div.1 B. Suspects
这题目乍眼一看还以为是2-sat.其实很水的,O(n)就解了.枚举每个人,假设其作为凶手.观察是否满足条件.然后再对满足的数目分类讨论,进行求解. /* 156B */ #include <io ...
- 【CF】222 Div.1 B Preparing for the Contest
这样类似的题目不少,很多都是一堆优化条件求最优解,这个题的策略就是二分+贪心.对时间二分, 对费用采用贪心. /* 377B */ #include <iostream> #include ...
- 【CF】207 Div.1 B.Xenia and Hamming
这题目一看很牛逼,其实非常easy.求求最小公倍数,最大公约数,均摊复杂度其实就是O(n). /* 356B */ #include <iostream> #include <str ...
- 【CF】142 Div.1 B. Planes
SPFA.注意状态转移条件,ans的求解需要在bfs中间求解.因为只要到了地点n,则无需等待其他tourist.还是蛮简单的,注意细节. /* 229B */ #include <iostrea ...
- 【CF】196 Div.2 D. Book of Evil
显然这个图是一课树,看着题目首先联想到LCA(肯定是可以解的).但是看了一下数据大小,应该会TLE.然后,忽然想到一个前面做过的题目,大概是在一定条件下树中某结点旋转成为根后查询最长路径.结果灵感就来 ...
- 【CF】223 Div.1 C Sereja and Brackets
水线段树. /* 380C */ #include <iostream> #include <string> #include <map> #include < ...
- 【CF】259 Div.1 B Little Pony and Harmony Chest
还蛮有趣的一道状态DP的题目. /* 435B */ #include <iostream> #include <string> #include <map> #i ...
随机推荐
- Base64 encode/decode large file
转载:http://www.cnblogs.com/jzywh/archive/2008/04/20/base64_encode_large_file.html The class System.Co ...
- 获取汉字拼音 Java
两种方法:一个是使用btye数组,一个是引入jar包进行操作. 1. public class CharacterParser { private static int[] pyvalue = new ...
- Ext.Net学习笔记14:Ext.Net GridPanel Grouping用法
Ext.Net学习笔记14:Ext.Net GridPanel Grouping用法 Ext.Net GridPanel可以进行Group操作,例如: 如何启用Grouping功能呢?只需要在Grid ...
- MAC itunes无法验证服务器s.mzstatic/itunes无法更新服务器解决方案
打开host文件: 一.用终端打开: sudo vi /etc/hosts 输入完这行命令后需要输入电脑密码,然后确认,进入host文件 然后按i键进入编辑模式,在最后一行添加:23.214.233. ...
- Xcode中实现ARC和MRC混编
1.在Xcode中打开项目文件 2.选中项目名称 3.在右侧选择build phass 选项卡 4.选择 complite source 选项 5.选择要支持MRC编译的.m文件,双击 6.在弹出的框 ...
- spring mvc 错误
No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin //跨域问题 respons ...
- 10.15_SVG可以解决问题吗
(1)淘宝开放平台. (2)Teiid是一个数据虚拟化系统.Dubbo 是阿里巴巴公司开源的一个高性能优秀的服务框架.Apache Jackrabbit. (3)SVG:百度百科.SVG.js .Sn ...
- 【培训】交换机VLAN
为了解决用交换机做LAN互联无法限制广播的问题,出现了VLAN技术,把一个LAN划分为多个逻辑的“LAN”-VLAN. VLAN技术将一个物理的LAN逻辑地划分为不同的广播域,每一个VLAN包含一组有 ...
- Headfirst设计模式的C++实现——装饰者模式(Decorater)
Beverage.h #ifndef BEVERAGE_H_INCLUDED #define BEVERAGE_H_INCLUDED #include <string> class Bev ...
- 《APUE》第三章笔记(3)
文件共享 UNIX系统支持在不同进程中共享打开的文件,首先先用一幅apue的图来介绍一下内核用于I/O文件的数据结构: 如图所见,一个进程都会有一个记录项,记录项中包含有一张打开文件描述符表,每个描述 ...