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

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

/**
* Definition of SegmentTreeNode:
* class SegmentTreeNode {
* public:
*     int start, end, count;
*     SegmentTreeNode *left, *right;
*     SegmentTreeNode(int start, int end, int count) {
*         this->start = start;
*         this->end = end;
*         this->count = count;
*         this->left = this->right = NULL;
*     }
* }
*/
class Solution {
public:
/**
*@param root, start, end: The root of segment tree and
*                         an segment / interval
*@return: The count number in the interval [start, end]
*/
int query(SegmentTreeNode *root, int start, int end) {
if(!root)return 0;
if (root->start>end)return 0;
if (root->end < start)return 0;
if (root->start > start)start = root->start;
if (root->end < end)end = root->end;
if (start == root->start&&end == root->end)return root->count;

SegmentTreeNode *left = root->left, *right = root->right;
if (start >= right->start){//完全在右侧
return query(right, start, end);
}
if (end <= left->end){//完全在左侧
return query(left, start, end);
}
return query(left, start, left->end)+query(right,right->start,end);//在左右之间
}
};


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

## lintcode-线段树查询II-247

/** * Definition of SegmentTreeNode: * class SegmentTreeNode { * public: * int start, end, c...

## 线段树：Balanced Lineup（pku 3264）（解题报告）

Balanced Lineup            Time Limit: 5000MS    Memory Limit: 65536K  Total Submissions: 1166...

## Hdu 1754 I Hate It 线段树 解题报告

• Hawo11
• 2017年07月21日 19:44
• 113

## 线段树和单调队列优化DP---POJ2373解题报告

• pi9nc
• 2013年07月25日 10:34
• 546

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