• 带头结点的中序线索化


    可能编译时会有些语法小错误(比如分号,->,等),很容易就自己纠正了哦,思路绝对是完全正确的,所以用的话就自己试着改改吧,直接复制粘贴,就正确,岂不是太没写代码体验了,自己改改才印象更加深刻的呢()~~~~;

    //带头结点的中序线索化
    #include<iostream>
    using namespace std;
    
    typedef struct BiThrNode{
        char data;
        struct BiThrNode *lchild,*rchild;
        int LTag,RTag;
    }BiThrNode,*BiThrTree;
    
    BiThrNode *pre=new BiThrNode;
    
    void CreateBiTree(BiThrTree &T){
        char ch;
        cin>>ch;
        if(ch=='#') T=NULL;
        else{
            T=newBiThrNode;
            T->data=ch;
            CreateBiTree(T->lchild);
            CreateBiTree(T->rchild);
        }
    }
    
    void InThreading(BiThrTree p){
        if(p){
            InThreading(p->lchild);
            if(!p->lchild){
                p->LTag=1;
                p->lchild=pre;
            }else{
                p->LTag=0;
            }
    
            if(!pre->rchild){
                pre->RTag=1;
                pre->rchild=p;
            }else{
                pre->RTag=0;
            }
            pre=p;
            InThreading(p->rchild);
        }
    }
    
    void InOrderThreading(BiThrTree &Thrt,BiThrTree T){
        Thrt=new BiThrNode;
        Thrt->LTag=0;
        Thrt->RTag=1;
        Thrt->rchild=Thrt;
        if(!T) Thrt->lchild=Thrt;
        else{
            Thrt->lchild=T;pre=Thrt;
            InThreading(T);
            pre->rchild=Thrt;
            pre->RTag=1;
            Thrt->rchild=pre;
        }
    }
    
    void main(){
        pre->RTag=1;
        pre->rchild=NULL;
        BiThrTree tree,Thrt;
        cout<<"please:
    ";
        CreateBiTree(tree);
        InThreading(Thrt,tree);
        cout<<"finish:
    ";
    }
    
  • 相关阅读:
    Swift_数据存储
    Swift_零碎知识
    Flutter安装与使用
    供热
    iOS_2022_动画
    依赖管理
    Swift_协议
    Swift_网络请求
    数据转换的使用
    Map相关、MapUtils、MultiMap、LazyMap、BidiMap
  • 原文地址:https://www.cnblogs.com/ygjzs/p/11874608.html
Copyright © 2020-2023  润新知