网络杂谈
二叉树转换为树是树转换为二叉树的逆过程,其步骤是: (1)若某结点的左孩子结点存在,将左孩子结点的右孩子结点、右孩子结点的右孩子结点……都作为该结点的孩子结点,将该结点与这些右孩子结点用线连接起来; (2)删除原二叉树中所有结点与其右孩子结点的连线; (3)整理(1)和(2)两步得到的树,使之结构层次分明。 转换以后的
传统的二叉链表仅能体现出一种父子关系,不能直接得到结点在遍历中的前驱或后继。引入【线索二叉树】正是为了加快查找结点前驱和后继的速度。 (1、定义: 前驱与后继:在二叉树的先序、中序或后序遍历序列中的两个相邻的结点; 线索:指向前驱或后继的结点的指针; 线索二叉树:加上线索的二叉链表的二叉树; 线索化:
因为线索化后, 各个结点指向有变化, 因此原来的遍历方式不能使用, 需要使用新的方式遍历线索化二叉树。 中序线索二叉树的结点中隐含了线索二叉树的前驱和后继信息。 在对其遍历时,需要找到第一个具有前驱结点的左结点,然后依次找结点的后继。 在中序线索二叉树中找结点后继的规律是: 若其右标志为1,则右链为线索,指
散列函数 在进行查找时,在记录的存储位置与它的关键字之间建立一个确定的对应关系h,以线性表中每个元素的关键字K为自变量,通过函数h(K)计算出该元素的存储位置,我们将h函数称为散列函数或哈希函数。h(K)的值称为散列地址或哈希地址。 冲突 在实际应用中,通常可能出现一个待插入元素的散列地址单元已被占用
深度优先搜索类似于树的先序遍历。 其基本思想是: 首先访问起始顶点v,然后由v出发,访问与v 邻接且未被访问的任一顶点w1,再访问与w1 邻接且未被访问的任一顶点W2……重复上述操作。 当不能再继续向下访问时,依次退回到最近被访问的顶点,若它还有邻接顶点未被访问过,则从该点开始继续上述搜索过程,直至图中所有
通过迪杰斯特拉算法计算图G中的最短路径时,需要指定起点s。 此外,需要引进两个集合S和U。 S的作用:记录已求出最短路径的顶点(以及相应的最短路径长度), U的作用:记录还未求出最短路径的顶点(以及该顶点到起点s的距离)。 初始时,S中只有起点s; U中是除s之外的顶点,并且U中顶点的路径是“起