很久之前我就想过怎么快速在二维平面上查找一个区域的信息,思考许久无果,只能想到几种优秀一点的暴力. Kd树就是干上面那件事的. 别的不多说,赶紧把自己的理解写下来,免得凉了. KD树的组成 以维护k维空间(x,y,……)内的KD树为例,主要由一下三部分组成: p[k],代表树上这个结点所储存的点(在题目中给出的/你自己加上的点集中的一个点). ch[2],表示它的子结点(没错,KD树是一棵二叉树) mi[k]与mx[k],mi/mx[i]代表KD树这个结点统辖的所有点的第i-1范围.比如说mi[…