解题报告:线段树的查询

原创 2015年07月09日 13:11:37

http://www.lintcode.com/zh-cn/problem/segment-tree-query/

/**
 * Definition of SegmentTreeNode:
 * class SegmentTreeNode {
 * public:
 *     int start, end, max;
 *     SegmentTreeNode *left, *right;
 *     SegmentTreeNode(int start, int end, int max) {
 *         this->start = start;
 *         this->end = end;
 *         this->max = max;
 *         this->left = this->right = NULL;
 *     }
 * }
 */
class Solution {
public:
    /**
     *@param root, start, end: The root of segment tree and 
     *                         an segment / interval
     *@return: The maximum number in the interval [start, end]
     */
    int query(SegmentTreeNode *root, int start, int end) {
        // write your code here
       if (root == nullptr)return 0;
		SegmentTreeNode *left = root->left, *right = root->right;
		if (end<root->start)return 0;//end超出了最左
		if (start>root->end)return 0;//start超出了最右
		if (start<root->start)start = left->start;//start超出了最左
		if (end>root->end)end = right->end;//end超出了最右
		if (start == root->start&&end == root->end)return root->max;
		if (left->end >= end){//完全左侧
			return query(left, start, end);
		}
		if (right->start <= start){//完全右侧
			return query(right, start, end);
		}
		return  max(query(left, start, left->end), query(right, right->start, end));//左右之间都有
    }
};


POJ 4047 Garden (线段树 - 区间增减、区间查询) -- 解题报告

题面 Garden Time Limit: 1000MS Memory Limit: 65536K Description There are n flowerpots in...

线段树 查询删除 后序遍历 POJ2182 Lost Cows解题报告

线段树 查询删除 后序遍历 POJ2182 Lost Cows解题报告

CF 457C Elections 解题报告(线段树)

C. Elections time limit per test 2 seconds memory limit per test 256 megabytes inpu...
  • kbdwo
  • kbdwo
  • 2014年08月11日 20:34
  • 679

Binary Simulation 解题报告--线段树

Description Given a binary number, we are about to do some operations on the number. Two types of...

poj3468- A Simple Problem with Integers-解题报告-线段树

题目链接:http://poj.org/problem?id=3468 这道题也是不能更新到叶节点~~会超时滴,可以成段更新,询问时再向下更新,这样可以省去一些更新不被查询的节点的时间 实现方法是...

SDUT 3513 皮卡丘的梦想 (二进制+线段树) -- 解题报告

题面 皮卡丘的梦想 Time Limit: 1000ms Memory limit: 65536K 题目描述 一天,一只住在 501 的皮卡丘决定发奋学习,成为像 Lei...

HDU1166 敌兵布阵 解题报告--线段树

敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub...

线段树 ST算法 RMQ poj 3264 Balanced Lineup 解题报告

线段树 ST算法 RMQ poj 3264 Balanced Lineup 解题报告

【解题报告】 HDU 2795 Billboard -- 线段树的应用

题目大意:有一个广告板,告诉我们尺寸(即高度宽度),我们要贴广告,广告的尺寸规定为1*w,我们每次从最左上面开始贴,当给出的广告不够贴时,移到下一行贴。输出当前广告贴在第几行。 题目连接:->  H...

HDU3074 Multiply game 解题报告--线段树

Multiply game Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:解题报告:线段树的查询
举报原因:
原因补充:

(最多只允许输入30个字)