《算法导论》第12章 二叉查找树 (1)遍历

53 篇文章 1 订阅


二叉查找树的效率

在二叉查找树中执行的基本操作的时间与树的高度成正比。最坏情况,
树的高度是N,像链表一样,而较好情况高度是lgN。因此,树的高度是关键。
下一章将要学习的红黑树是对二叉查找树的改进,通过保持树的高度从而
保证红黑树上的操作有很好的效率。


各种遍历算法

中序遍历算法:子树根的关键字在输出时介于左子树和右子树的关键字之间。
即按排列顺序输出树中的所有关键字。

相应的,前序遍历就是子树根的关键字在左右子树之前输出。
在后面的基数树中,前序遍历(而非中序遍历)是二进制串的排序输出。

用递归方式可以很轻松地实现二叉树的遍历。

// 包含卫星数据的二叉树结点定义
struct _BSTNode {
     struct _BSTNode *parent, *left, *right;    
     int key;    
     char *value;
};

typedef struct _BSTNode BSTNode;

// 中序遍历
void bst_inorder_walk(BSTNode *node)
{
     if (node != NULL) {
          bst_inorder_walk(node->left);
          printf("key: %d, val: %s\n", node->key, node->value);
          bst_inorder_walk(node->right);
     }         
}


非递归实现中序遍历

沿着二叉树的最左结点遍历,逐个入栈,到最左结点后开始出栈。
打印弹出栈的结点的值,并以该结点的右孩子为根结点,继续沿其最左结点处理。

void bst_inorder_walk(BSTNode *node)
{
     BSTNode *stack[20];
     int top = 0;     

     while (node || top != 0) {     
          // Push most-left children to stack
          while (node) {
               stack[top++] = node;
               node = node->left;
          }

          // Print and continue to handle right child
          node = stack[--top];
          printf("%d, %s\n", node->key, node->value);
          node = node->right;
               
     }
}




  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值