线段树的查找:
一个线段树的结点表示一个区间,同时结点中保存所需要的信息。
如果询问区间正好为这个线段树的区间(左边界和右边界都相同),则返回该结点中保存的信息。
否则,递归往下查询该结点的子结点(之后再返回的值就是子结点的值了,与当前结点无关了)
一直到“元线段”-不可再分之线段。
线段树的结点的区间包含所有子结点的区间,并且子结点只有两个,同时子结点区间为父结点的一半,(二叉树)
往下查询的时候判断询问区间是否与当前结点表示区间的左右区间覆盖,有三种情况
1,查询区间在该结点表示区间中点右边,此时只需要往右孩子查询
2.查询区间在该结点表示区间中点左边,此时只需要往左孩子查询
3.查询区间包含该结点中点,这个时候要把查询区间一分为2,即查询区间的左边界到中点,往左孩子查询,以及中点到查询区间的右边界,往右孩子查询。