# 解题报告：线段树的查询

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) {
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));//左右之间都有
}
};


• 本文已收录于以下专栏：

## CF 457C Elections 解题报告（线段树）

C. Elections time limit per test 2 seconds memory limit per test 256 megabytes inpu...
• 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...

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

Multiply game Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

举报原因： 您举报文章：解题报告：线段树的查询 色情 政治 抄袭 广告 招聘 骂人 其他 (最多只允许输入30个字)