数据结构——树 总结篇

以后把遇到的树的问题都总结在这一篇里啦~

1.普通的树的数据结构表示

struct TreeNode{
TYPE element;//该节点的元素
TreeNode *firstChild;//指向该节点的第一个孩子
TreeNode *nextSibling;//指向该节点的兄弟节点
};

http://blog.csdn.net/linux_ever/article/details/51063795


2.二叉树的前中后序遍历。

递归就不写了。

非递归的话要利用栈。

http://www.cnblogs.com/dolphin0520/archive/2011/08/25/2153720.html


3.Morris 遍历

一种不利用栈的遍历方式,但是时间上稍微慢一点

我们知道,在深度搜索遍历的过程中,之所以要用递归或者是用非递归的栈方式,都是因为其他的方式没法记录当前节点的parent,而如果在每个节点的结构里面加个parent 分量显然是不现实的,那么Morris是怎么解决这一问题的呢?好吧,他用得很巧妙,实际上是用叶子节点的空指针来记录当前节点的位置,然后一旦遍历到了叶子节点,发现叶子节点的右指针指向的是当前节点,那么就认为以当前节点的左子树已经遍历完成。

以inorder为例,初始化当前节点为root,它的遍历规则如下:

    如果当前节点为空,程序退出。
    如果当前节点非空,
        如果当前节点的左儿子为空,那么输出当前节点,当前节点重置为当前节点的右儿子。
        如果当前节点的左儿子非空,找到当前节点左子树的最右叶子节点(此时最右节点的右儿子有两种情况,一种是指向当前节点,一种是为空,你也许感到奇怪,右节点的右儿子怎么可能非空,注意,这里的最右叶子节点只带的是原树中的最右叶子节点。),若其最右叶子节点为空,令其指向当前节点,将当前节点重置为其左儿子,若其最右节点指向当前节点,输出当前节点,将当前节点重置为当前节点的右儿子,并恢复树结构,即将最右节点的右节点再次设置为NULL

http://www.cnblogs.com/AnnieKim/archive/2013/06/15/MorrisTraversal.html


4.BFS

昨天面试题问到的,找一棵二叉搜索树中两个给定节点的最小公共祖先。

我们只需要从根结点开始和两个结点进行比较。如果当前结点的值比两个结点都大,则最低的共同父结点一定在当前结点的左子树中。如果当前结点的值比两个结点都小,则最低的共同父结点一定在当前结点的右子树中。如果一个大一个小,就可以return。

那么对于普通的树呢?我的想法是维护两个栈,然后找到从根到两个节点的路径,一直pop直到两个栈的top相等为止。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值