按对称序线索二叉树总结之建立

对称序二叉树的意义就是能够很方便的找出前驱和后继
数据结构

struct ThrTreeNode;
typedef struct ThrTreeNode *PThrTreeNode;
struct ThrTreeNode{
  DataType info;
  PThrTreeNode llink,rlink;
  int ltag,rtag;
};
typedef struct ThrTreeNode *ThrTree;
typedef ThrTree *PThrTree;

建立(画草图跟着走理解起来会更方便)

void thread(ThrTree t)
{
  PSeqStack st = createEmptyStack(M);//M一般为T的高度
  ThrTree p,pr;
  if(t == NULL)
    return;
  p=t;pr=NULL;
  do{
      while(p!=NULL){
        push_seq(st,p); 
        p=p->llink;  //往左一直走,直到最左节点
      }
      p=top_seq(st);
      pop_seq(st); //栈顶弹栈 p一直指向当前被访问的节点
      if(pr!=NULL){  
        if(pr->rlink == NULL){ 
          pr->rlink=p;pr->rtag=1; //将右节点指向其后继
        }
        if(p->llink == NULL){
          p->llink=pr;p->ltag = 1; //将左节点指向其前驱
        }
      }
        pr=p;p=p->rlink;  //(pr指向被访问点的前驱),指向右子树
    }while(!isEmptyStack_seq(st) || p!=NULL)
 }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值