线段树查询2
来源:互联网 发布:linux 切换root用户 编辑:程序博客网 时间:2024/05/29 06:36
对于一个数组,我们可以对其建立一棵 线段树
, 每个结点存储一个额外的值 count
来代表这个结点所指代的数组区间内的元素个数. (数组中并不一定每个位置上都有元素)
实现一个 query
的方法,该方法接受三个参数 root
, start
和 end
, 分别代表线段树的根节点和需要查询的区间,找到数组中在区间[start, end]内的元素个数。
/** * 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==NULL||start>end||start>root->end||end<root->start) return 0; int mid=root->start+(root->end - root->start)/2; if(start==root->start&&end==root->end) return root->count; if(root->start==root->end) return root->count; if(start>mid) return query(root->right,start,end); if(end<=mid) return query(root->left,start,end); return query(root->left,start,mid)+query(root->right,mid+1,end); }};
0 0
- 线段树查询2
- 线段树查询
- 线段树的查询
- 线段树查询 II
- 线段树的查询
- 线段树查询 II
- 线段树查询 II
- 线段树区间查询
- LintCode:线段树的查询
- 线段树(建树,查询)
- [线段树][区间修改&&查询]
- HDU4288Coder(线段树+离线查询)
- 线段树的查询-LintCode
- 线段树查询 II-LintCode
- 线段树--动态区间查询
- <LeetCode> 题247:线段树的查询(2)
- [BZOJ3110]K大数查询|线段树套线段树
- BSOJ3723:ZJOI2013 k大数查询 线段树套线段树
- android悬浮窗口的实现 Windowmanager
- JavaScript高级程序设计之基本概念之操作符之加性操作符第3.5.5讲笔记
- 201509——hulu笔试题目——rainfall
- JAVA多线程实现的三种方式
- CMS垃圾收集器介绍
- 线段树查询2
- JavaScript高级程序设计之基本概念之关系操作符第3.5.6讲笔记
- java线程池newCachedThreadPool
- QT qDebug输出QString的中文乱码,直接输出“中文”不乱码,解决方法
- HTML中的块是什么?
- 全排序 java实现
- android学习各种bug(5)
- 列出一个文件夹下面的所有文件
- JavaScript高级程序设计之基本概念之相等操作符第3.5.7讲笔记