/**
* 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) {
// write your code here
if(root == NULL) { return 0; }
if(start > end || start > root->end || end < root->start) { return 0; }
if(start <= root->start && end >= root->end) { return root->count; }
int mid = (root->start + root->end) / 2;
int left = query(root->left, start, min(mid, end));
int right = query(root->right, max(mid, start), end);
return left+right;
}
};
lintcode-Segment Tree Query II
最后編輯于 :
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
- 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
- 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
- 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
推薦閱讀更多精彩內容
- 原題 對于一個數組,我們可以對其建立一棵線段樹, 每個結點存儲一個額外的值count來代表這個結點所指代的數組區間...
- 原題 LintCode 70. Binary Tree Level Order Traversal II Desc...
- 原題 對于一個有n個數的整數數組,在對應的線段樹中, 根節點所代表的區間為0-n-1, 每個節點有一個額外的屬性m...
- 【題目描述】 For an array, we can build a Segment Tree for it, ...