- 浏览: 120459 次
- 性别:
- 来自: 北京
最新评论
查询最左端的连续空房间,思想是二分,不过是在线段树上做的二分,所以线段树结点上需要记录一些附加信息,为二分提供条件
又WA了几次才过的,总结经验就是:
更新区间的过程,递归进入子节点前,如果父节点被完全覆盖(在之前的操作中整个区间被修改为住人或空房),那么要相应地修改子节点;从子节点回溯出来后,根据子节点的情况更新父节点。
查询区间的过程也是,要考虑父节点被完全覆盖的情况,这时就不用再往下递归了
又WA了几次才过的,总结经验就是:
更新区间的过程,递归进入子节点前,如果父节点被完全覆盖(在之前的操作中整个区间被修改为住人或空房),那么要相应地修改子节点;从子节点回溯出来后,根据子节点的情况更新父节点。
查询区间的过程也是,要考虑父节点被完全覆盖的情况,这时就不用再往下递归了
#include <cstdio> const int maxN = 50000 + 5; struct node_t { int ll, mm, rr; } tree[maxN * 3]; int max3(int x, int y, int z) { x = x > y ? x : y; x = x > z ? x : z; return x; } int left, right; bool checkIn; void check(int low, int high, int node) { if (left <= low && high <= right) { tree[node].ll = tree[node].mm = tree[node].rr = (checkIn ? 0 : high - low + 1); } else if (left <= high && low <= right) { node_t &lch = tree[node * 2], &rch = tree[node * 2 + 1]; int mid = (low + high) / 2; if (tree[node].mm == high - low + 1) { lch.ll = lch.mm = lch.rr = mid - low + 1; rch.ll = rch.mm = rch.rr = high - mid; } if ((tree[node].ll | tree[node].mm | tree[node].rr) == 0) { lch.ll = lch.mm = lch.rr = 0; rch.ll = rch.mm = rch.rr = 0; } check(low, mid, node * 2); check(mid + 1, high, node * 2 + 1); tree[node].ll = lch.ll + (lch.ll == mid - low + 1 ? rch.ll : 0); tree[node].rr = (rch.rr == high - mid ? lch.rr : 0) + rch.rr; tree[node].mm = max3(lch.rr + rch.ll, lch.mm, rch.mm); } } int need; int find(int low, int high, int node) { if (tree[node].mm == high - low + 1 || (tree[node].ll | tree[node].mm | tree[node].rr) == 0) { if (tree[node].mm >= need) return low; } else if (low < high) { if (tree[node].ll >= need) return low; int mid = (low + high) / 2; node_t &lch = tree[node * 2], &rch = tree[node * 2 + 1]; if (tree[node].mm >= need) { if (lch.mm >= need) return find(low, mid, node * 2); if (lch.rr + rch.ll >= need) return mid - lch.rr + 1; if (rch.mm >= need) return find(mid + 1, high, node * 2 + 1); } if (tree[node].rr >= need) return high - tree[node].rr + 1; } return 0; } int main() { int N, M, req, X, D; scanf("%d%d", &N, &M); left = 1, right = N, checkIn = false; check(1, N, 1); while (M--) { scanf("%d", &req); if (req == 1) { scanf("%d", &D); need = D; X = find(1, N, 1); printf("%d\n", X); if (X != 0) { left = X, right = X + D - 1, checkIn = true; check(1, N, 1); } } else { scanf("%d%d", &X, &D); left = X, right = X + D - 1, checkIn = false; check(1, N, 1); } } return 0; }
发表评论
-
lower_bound and upper_bound
2012-02-09 00:36 1183/** * @brief Finds the ... -
HDU 3954
2012-02-05 10:43 863线段树变种,也是在2logn段上面做文章 /* * ... -
HDU 4027
2012-02-04 22:09 885线段树变种 在2logn段上面做文章,swap(x, y)太阴 ... -
ICPC编码建议
2011-10-28 09:52 938写代码最重要的是清晰,包括思路的清晰和代码结构的清晰。我们无法 ... -
[转载]TopCoder插件
2011-09-08 22:13 1006转载自:http://acm.cugb.edu.cn/blog ... -
UVALive 5112 - Sales Prediction
2011-01-06 10:19 1220封装了矩阵类 比赛做得很郁闷,为什么别人写得很长、很罗嗦的代码 ... -
hdu 3236
2010-12-12 14:10 825终于能过这道题了,算是背包必做题之一吧 /* * Au ... -
pku 1018
2010-12-11 15:18 645写了两三个版本,最后这个效率最高 #include < ... -
布斯(Booth)乘法
2010-10-07 19:59 1169源自http://watashi.ws/blog/1515/z ... -
高斯消元
2010-10-07 14:18 833import java.util.*; import j ... -
整数划分
2010-10-07 10:38 858#include <cstdio> #inc ... -
Treap
2010-09-18 22:19 1004// Treap // Tested: bjtu1057 ... -
矩阵快速幂
2010-09-18 14:24 1071typedef LL matrix[55][55]; ... -
maximum clique 最大团
2010-09-02 18:12 1166最大团模板 #include <cstdio> ... -
计算Jacobi符号
2010-08-31 13:15 1332Quadratic reciprocity The Jacob ... -
Java 高效I/O
2010-08-19 16:54 806static BufferedReader cin = ... -
DLX pku 3076
2010-08-11 23:45 918标准数独,精确覆盖 // pku3076.cpp #in ... -
DLX hust 1017
2010-08-11 16:50 878“精确覆盖”问题 #include <cstdio& ... -
DLX hdu 3498
2010-08-11 16:48 1079“多重覆盖”或“重复覆盖”问题 #include < ... -
hdu 3509
2010-08-09 11:22 1024推导公式的题目,矩阵幂关键就在于构造系数矩阵 备忘: S(n, ...
相关推荐
【标题】"pku.zip_PKU" 指的是一份与北京大学(Peking University, PKU)相关的压缩文件。从描述来看,这份压缩包包含了部分编程题目的代码,可能是学生或者爱好者在解决北京大学编程竞赛或课程作业时编写的。"pku"这...
"pku经典题目解题报告"这一标题揭示了文件内容的核心,它表明这是一份关于北京大学(PKU)编程竞赛或算法竞赛中的经典问题的解答集。通常,这样的报告会涵盖一系列在PKU历年比赛中出现的难题,包含了解题思路、算法...
pku1000 pku1000程序 解题报告
在编程竞赛的世界里,北京大学(PKU)的ACM团队以其高质量的题目和独特的解题思路闻名。"PKU-ACM.rar"这个压缩包包含了北大ACM题目的一些核心知识点,旨在帮助参赛者理解和掌握算法竞赛中的生命周期题目解法。本文将...
benchmark (PKU-MMD) for continuous multi-modality 3D human action understanding and cover a wide range of complex human activities with well annotated information. PKU-MMD contains 1076 long video ...
【标题】"PKU 课件 ppt 等 灰常强大" 指的是北京大学(PKU)的课程资料,其中包括了PPT演示文稿和其他相关文档资源,这些资料质量高、内容丰富,对学习者来说具有极高的价值。"灰常强大"这一网络用语表明这些课件...
【标题】"ACM代码 之pku代码" 涉及的是在计算机科学领域中的算法竞赛编程,尤其是北京大学(Peking University, PKU)的ACM/ICPC(国际大学生程序设计竞赛)训练代码。这些代码是参赛者或教练为了准备这类竞赛而编写的,...
标题 "pku acm 一些代码" 暗示了这是一个与北京大学(Peking University, 简称PKU)的ACM(国际大学生程序设计竞赛)相关的代码集合。在这个领域,参赛者通常需要解决算法问题,编写高效且优化的代码来求解数学、逻辑...
标题"Pku1664"很可能是指北京大学(Peking University)在某个编程竞赛或课程中的一道题目或项目,编号为1664。这道题目可能涉及到计算机科学的基础概念,尤其是算法和数据结构。描述中提到的是"Pku1664源代码",暗示...
8数码代码pku1077,300ms(哈希+广度搜索)
PKU 2339 Rock, Scissors, Paper 源代码
pku acm 1469 COURSES 代码 二分图的最大匹配的匈牙利算法 解题报告请访问:http://blog.csdn.net/china8848
标题中的“pku1742.rar_pku 17_pku 1742 _报告及程序”表明这是一个与北京大学(Peking University, 简称PKU)相关的项目,项目编号可能是1742,内容包括了结题报告和程序代码。这个压缩包很可能是学生或研究人员提交...
北京大学pku2317 Questions and answers c++标程 文件名为2371.cpp
标签部分进一步细化了内容:"pku acm_pku"再次强调这是北京大学ACM竞赛的资料,"pku__1709__crossword"可能是特定的题目标签,而"pku_acm"可能是北京大学ACM团队的标识。"visual_c"可能表示这些代码是使用C++语言,...
"p_acm"、"pku_acm"以及"pu_acm.pku_pku"等标签可能是用于分类或标识这些代码属于北京大学(Peking University, PKU)的ACM训练题目。"acm"一词重复出现,进一步强调了这是关于ACM编程竞赛的内容。 描述中提到"acmer...
标题中的“pku1088.rar_pku 10_pku 1088_poj 1088”指的是北京大学(Peking University, PKU)编程竞赛中的第1088题,也称为POJ(Peking University Online Judge)的1088题。这个题目在编程竞赛社区中通常有一个特定的...
分词训练用的pku训练集,主要是说明相似度计算的样例数据。