线段树。线段树的细节很重要,小数据遍历可以发现问题。

 /* 4553 */
#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 l, r;
int nls, nrs, nms;
int dls, drs, dms;
} node_t; const int study = ;
const int ds = ;
const int ns = ;
const int maxn = 1e5+;
node_t nd[maxn<<]; void Build(int l, int r, int rt) {
nd[rt].l = l;
nd[rt].r = r;
nd[rt].nls = nd[rt].nrs = nd[rt].nms = r-l+;
nd[rt].dls = nd[rt].drs = nd[rt].dms = r-l+;
if (l == r)
return ; int mid = (l + r) >> ;
Build(lson);
Build(rson);
} void PushDown(int rt) {
int l = nd[rt].l, r = nd[rt].r;
if (l == r) return ;
int lb = rt<<;
int rb = lb |;
int mid = (l + r) >> ; if (nd[rt].dms == ) {
nd[lb].dls = nd[lb].drs = nd[lb].dms = ;
nd[rb].dls = nd[rb].drs = nd[rb].dms = ;
} else if (nd[rt].dms == r-l+) {
nd[lb].dls = nd[lb].drs = nd[lb].dms = mid - l + ;
nd[rb].dls = nd[rb].drs = nd[rb].dms = r - mid;
} if (nd[rt].nms == ) {
nd[lb].nls = nd[lb].nrs = nd[lb].nms = ;
nd[rb].nls = nd[rb].nrs = nd[rb].nms = ;
} else if (nd[rt].nms == r-l+) {
nd[lb].nls = nd[lb].nrs = nd[lb].nms = mid - l + ;
nd[rb].nls = nd[rb].nrs = nd[rb].nms = r - mid;
}
} void PushUp1(int rt) {
int l = nd[rt].l, r = nd[rt].r;
if (l == r) return ;
int lb = rt<<;
int rb = lb |;
int mid = (l + r) >> ; nd[rt].dls = nd[lb].dls;
nd[rt].drs = nd[rb].drs;
nd[rt].dms = max(nd[lb].dms, nd[rb].dms);
nd[rt].dms = max(nd[rt].dms, nd[lb].drs+nd[rb].dls); if (nd[lb].dls == mid - l + )
nd[rt].dls += nd[rb].dls;
if (nd[rb].drs == r - mid)
nd[rt].drs += nd[lb].drs;
} void PushUp2(int rt) {
int l = nd[rt].l, r = nd[rt].r;
if (l == r) return ;
int lb = rt<<;
int rb = lb |;
int mid = (l + r) >> ; nd[rt].nls = nd[lb].nls;
nd[rt].nrs = nd[rb].nrs;
nd[rt].nms = max(nd[lb].nms, nd[rb].nms);
nd[rt].nms = max(nd[rt].nms, nd[lb].nrs+nd[rb].nls); if (nd[lb].nls == mid - l + )
nd[rt].nls += nd[rb].nls;
if (nd[rb].nrs == r - mid)
nd[rt].nrs += nd[lb].nrs;
} int query1(int qt, int rt) {
PushDown(rt); if (nd[rt].dms < qt)
return ; if (nd[rt].dls >= qt)
return nd[rt].l; if (nd[rt<<].dms >= qt)
return query1(qt, rt<<); if (nd[rt<<].drs + nd[rt<<|].dls >= qt)
return nd[rt<<].r - nd[rt<<].drs + ; return query1(qt, rt<<|);
} int query2(int qt, int rt) {
PushDown(rt); if (nd[rt].nms < qt)
return ; if (nd[rt].nls >= qt)
return nd[rt].l; if (nd[rt<<].nms >= qt)
return query2(qt, rt<<); if (nd[rt<<].nrs + nd[rt<<|].nls >= qt)
return nd[rt<<].r - nd[rt<<].nrs + ; return query2(qt, rt<<|);
} void update0(int L, int R, int rt) {
if (L<=nd[rt].l && nd[rt].r<=R) {
nd[rt].nls = nd[rt].nrs = nd[rt].nms = nd[rt].r-nd[rt].l+;
nd[rt].dls = nd[rt].drs = nd[rt].dms = nd[rt].r-nd[rt].l+;
return ;
} PushDown(rt);
int mid = (nd[rt].l + nd[rt].r) >> ; if (mid >= R) {
update0(L, R, rt<<);
} else if (mid < L) {
update0(L, R, rt<<|);
} else {
update0(L, R, rt<<);
update0(L, R, rt<<|);
} PushUp1(rt);
PushUp2(rt);
} void update1(int L, int R, int rt) {
if (L<=nd[rt].l && nd[rt].r<=R) {
nd[rt].dls = nd[rt].drs = nd[rt].dms = ;
return ;
} PushDown(rt);
int mid = (nd[rt].l + nd[rt].r) >> ; if (mid >= R) {
update1(L, R, rt<<);
} else if (mid < L) {
update1(L, R, rt<<|);
} else {
update1(L, R, rt<<);
update1(L, R, rt<<|);
} PushUp1(rt);
} void update2(int L, int R, int rt) {
if (L<=nd[rt].l && nd[rt].r<=R) {
nd[rt].nls = nd[rt].nrs = nd[rt].nms = ;
nd[rt].dls = nd[rt].drs = nd[rt].dms = ;
return ;
} PushDown(rt);
int mid = (nd[rt].l + nd[rt].r) >> ; if (mid >= R) {
update2(L, R, rt<<);
} else if (mid < L) {
update2(L, R, rt<<|);
} else {
update2(L, R, rt<<);
update2(L, R, rt<<|);
} PushUp1(rt);
PushUp2(rt);
} int main() {
ios::sync_with_stdio(false);
#ifndef ONLINE_JUDGE
freopen("data.in", "r", stdin);
freopen("data.out", "w", stdout);
#endif int t;
int n, q;
int qt, l, r, ans;
char cmd[]; scanf("%d", &t);
rep(tt, , t+) {
scanf("%d %d", &n, &q);
Build(, n, );
printf("Case %d:\n", tt);
while (q--) {
scanf("%s", cmd);
if (cmd[] == 'S') {
scanf("%d %d", &l, &r);
update0(l, r, );
puts("I am the hope of chinese chengxuyuan!!");
} else if (cmd[] == 'D') {
scanf("%d", &qt);
l = query1(qt, );
if (l == ) {
puts("fly with yourself");
} else {
printf("%d,let's fly\n", l);
update1(l, l+qt-, );
}
} else if (cmd[] == 'N') {
scanf("%d", &qt);
l = query1(qt, );
if (l == )
l = query2(qt, );
if (l == ) {
puts("wait for me");
} else {
printf("%d,don't put my gezi\n", l);
update2(l, l+qt-, );
}
}
}
} #ifndef ONLINE_JUDGE
printf("time = %d.\n", (int)clock());
#endif return ;
}

【HDOJ】4553 约会安排的更多相关文章

  1. hdu 4553 约会安排

    约会安排 http://acm.hdu.edu.cn/showproblem.php?pid=4553 Time Limit: 2000/1000 MS (Java/Others)    Memory ...

  2. HDU - 4553 约会安排(区间合并)

    https://cn.vjudge.net/problem/HDU-4553 Description 寒假来了,又到了小明和女神们约会的季节.  小明虽为屌丝级码农,但非常活跃,女神们常常在小明网上的 ...

  3. HDU 4553 约会安排 (区间合并)【线段树】

    <题目链接> 寒假来了,又到了小明和女神们约会的季节.  小明虽为屌丝级码农,但非常活跃,女神们常常在小明网上的大段发言后热情回复“呵呵”,所以,小明的最爱就是和女神们约会.与此同时,也有 ...

  4. HDU 4553 约会安排(线段树区间合并+双重标记)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4553 题目大意:就是有三种操作: ①DS x,安排一段长度为x的空闲时间跟屌丝一起,输出这段时间的起点 ...

  5. E - Tunnel Warfare HDU - 1540 F - Hotel G - 约会安排 HDU - 4553 区间合并

    E - Tunnel Warfare HDU - 1540 对这个题目的思考:首先我们已经意识到这个是一个线段树,要利用线段树来解决问题,但是怎么解决呢,这个摧毁和重建的操作都很简单,但是这个查询怎么 ...

  6. hdu 4453 约会安排(线段树区间合并)

    约会安排 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total Submis ...

  7. M - 约会安排 - hdu 4553

    寒假来了,又到了小明和女神们约会的季节.  小明虽为�丝级码农,但非常活跃,女神们常常在小明网上的大段发言后热情回复“呵呵”,所以,小明的最爱就是和女神们约会.与此同时,也有很多基友找他开黑,由于数量 ...

  8. 约会安排HDU - 4553

    寒假来了,又到了小明和女神们约会的季节.  小明虽为屌丝级码农,但非常活跃,女神们常常在小明网上的大段发言后热情回复"呵呵",所以,小明的最爱就是和女神们约会.与此同时,也有很多基 ...

  9. 约会安排 HDU - 4553(线段树区间查询,区间修改,区间合并)

    题目: 寒假来了,又到了小明和女神们约会的季节.  小明虽为屌丝级码农,但非常活跃,女神们常常在小明网上的大段发言后热情回复“呵呵”,所以,小明的最爱就是和女神们约会.与此同时,也有很多基友找他开黑, ...

随机推荐

  1. Redis 集群常见问题

    Redis集群相关问题 1:远程连接问题 远程连接保护模式下,需要做一些配置.

  2. nyoj89 汉诺塔(二)

    题目网址 :http://acm.nyist.net/JudgeOnline/problem.php?pid=89 汉诺塔问题的经典结论: 把i个盘子从一个柱子整体移到另一个柱子最少需要步数是 2的i ...

  3. Android应用程序消息处理机制笔记

    看老罗的Android源码情景分析学习的时候,边抄边理解再总结.希望能为面试提供点帮助吧. 1.Android应用程序是通过消息来驱动,Android应用程序每一个线程在启动时,都可以首先在内部创建一 ...

  4. SEVERE: Class [ com/mysema/query/dml/DeleteClause ] not found

    SEVERE:   Class [ com/mysema/query/dml/DeleteClause ] not found. Error while loading [ class org.spr ...

  5. mkisofs出错解决办法

    使用mkisofs遇到错误: genisoimage: Uh oh, I cant find the boot catalog directory 'beini/boot/isolinux'! 使用的 ...

  6. 使windows server 2003 开机不显示登录页面

    1.运行“regedit”,以打开“注册表管理器”:运行注册表编辑器,依次展开[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsNT\CurrentVersi ...

  7. 配置nginx的负载均衡

    1.1   什么是负载均衡 负载均衡 建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽.增加吞吐量.加强网络数据处理能力.提高网络的灵活性和可用性. 负载均衡,英文名称 ...

  8. Scala - error: not found: value SortedMap

    先 IMPORT!!!! scala> import scala.collection._import scala.collection._ scala>  SortedMap(" ...

  9. /etc/rc.local ; /etc/init.d ;/etc/profile;/etc/bashrc;~/.bash_profile;~/.bashrc;~/.bash_logout

    1. /etc/rc.local 这是使用者自订开机启动程序,把需要开机自动运行的程序写在这个脚本里. 把脚本程序写在/etc/rc.d/init.d/目录下也可以  在完成 run level 3 ...

  10. xp 下卸载 硬盘安装的 ubuntu (本人的悲伤史)

    正常启动XP系统,到http://www.sysint.no 下载 MBRFIX.zip,解压,把文件放在C盘, 点击“开始”==“运行”==“cmd”,出现下面图 输入cd\,如下图, 再按回车键, ...