zoukankan      html  css  js  c++  java
  • 二叉树的遍历

    定义二叉树结点

    typedef struct Node{                    
        struct Node *lchild;
        char data;    
        struct Node *rchild;
    }BTNode;
    //层次遍历 
    void levelOrder(BTNode* root){
        if(root==NULL){
            return root;
        }
        Queue<BTNode*> queue = new Queue<>();                                                              
        in(queue,root); //根入    
       //一次出一个,出来的时候,把俩儿子(左在列前,右在列后)放进去。
        while(!isEmpty(queue)){                    
            BTNode*tmp = out(queue);                          
            printf("%c",tmp->data); 
            if(tmp->lchild!=NULL){                   
                in(queue,tmp->lchild);
            }
            if(tmp->rchild!=NULL){                 
                in(queue,tmp->rchild);
            }                                       
        }                                             
    }
    //先序递归遍历(即是深度优先遍历)
    void preOrder(BTNode* root ){
        if(root!=NULL){                            
            printf("%c",root->data); //访问根节点
            preOrder(root->lchild); //递归,先序遍历左子树 
            preOrder(root->rchild); //递归,先序遍历右子树 
        }
    }
    //先序非递归遍历
    void preOrder(BTNode* root) {
        if (root == null) {
            return;
        }
        Stack<BTNode*> stack = new Stack<>();
        add(root);//根入
        //一次出一个,出来的时候,把俩儿子(左在栈上,右在栈下)放进去。
        while (!isEmpty(queue)) {
            BTNode* tmp = pop(stack);
            printf("%c",tmp->data);
            if (tmp->rchild != null) { //右孩子压底备用
                push(stack,tmp->rchild);
            }
            if (tmp->lchild != null) {
                push(stack,tmp->lchild);
            }
        }
    }
    //中序递归遍历
    void  middleOrder(BTNode * root){
        if(root!=NULL){                            
            middleOrder(root->lchild); //递归,中序遍历左子树 
            printf("%c",root->data); //访问根节点
            middleOrder(root->rchild); //递归,中序遍历右子树 
        }
    } 
    
    //中序非递归遍历
    void middleOrder(BTNode* root) {
        if (root == null) {
            return;
        }
        Stack<TreeNode> stack = new Stack<>();
        TreeNode* tmp = root;
        while (tmp != NULL || !isEmpty(stack)) { 
            while (tmp != NULL) { //首次循环,左节点全部压入栈(左先)
                push(stack,tmp);
                tmp = tmp->lchild;
            }
            if (!isEmpty(stack)) {
                tmp = pop(stack); //首次循环,弹出最左边的节点
                printf("%c",tmp.data);
                tmp = tmp->rchild; //弹出左,顾其右(右为空,不压入,继续弹上左。)
            }
        }
    } 
    //后序递归遍历
    void postOrder(BTNode * pBt){
        if(pBt!=NULL){
            postOrder(pBt->lchild);
            postOrder(pBt->rchild);
            printf("%c",pBt->data);
        }
    }
    
    //后序非递归遍历
    void postOrder(BTNode* root) {
        if(root == null) {
            return;
        }
        Stack<BTNode*> stackTmp = new Stack<>();
        Stack<BTNode*> stackRes = new Stack<>();
        push(stackTmp,root);
        while (!isEmpty(stackTmp)) {
            BTNode* tmp = pop(stack1);
            push(stackRes,tmp); //将弹出的元素加到stackRes中,最后再输出。
            if (tmp->lchild != null) { //(左在临时栈下,右在临时栈上)
                push(stackTmp,tmp->lchild);
            }
            if (tmp->rchild != null) { 
                push(stackTmp,tmp->rchild);
            }
        }
        while (!isEmpty(stackRes)) {
           printf("%c",pop(stackRes)->data);
        }
    }
  • 相关阅读:
    Python:dict用法
    Ubuntu无法识别显示器情况下,高分辨率的设置
    select节点clone全解析
    js控制frameset的rows
    jQuery中事情的动态绑定 (转)
    jQuery动态添加表格1
    使用ajax,后台传回的数据处理
    Spring Boot 之构建Hello Word项目
    linux防火墙基本操作
    Vmware虚拟机中安装cnetOS7详细图解步骤
  • 原文地址:https://www.cnblogs.com/shijianchuzhenzhi/p/12390662.html
Copyright © 2011-2022 走看看