zoukankan      html  css  js  c++  java
  • 二叉树新的一种新建思路和遍历思路

    1.基础知识

    说明一点是:在C++中未给变量赋值,但是内存中也有他的内存空间

    #include<stdio.h>
    #include<stdlib.h>
    #include<iostream>
    #include <queue>
    
    using namespace std;
    
    typedef struct BTNode{
        int data;
        struct BTNode *lchild,*rchild;
    }BTNode;
    
    int main()
    {
        //new一个结点并进行构造函数初始化
        BTNode a1;  a1.data = 1;//这里的a1是普通变量
        //BTNode a1 = malloc 以前的a1是这个指针变量,接收的值是地址,并指向结构体的普通变量
        BTNode a2;  a2.data = 2;
        BTNode a3;  a3.data = 3;
    
    
        //建立连接关系
        a1.lchild = &a2;
        a1.rchild = &a3;
        a2.lchild = NULL; //变量a2.lchild接收的是地址
        a2.rchild = NULL; //a2.rchild是结构体指针变量
        a3.lchild = NULL;
        a3.rchild = NULL;
    
        //遍历二叉树
        queue<BTNode *> q1;
        BTNode *a =&a1; //a是当前访问的结点,a是结构体指针变量
    
        q1.push(&a1);      //算法1:根结点入队,地址入队
        while(!q1.empty()){//算法2:当队列不为空是循环
    
           cout<< q1.front()->data<<endl;    //算法3:弹出并访问队首元素
           a = q1.front(); //这一步很重要,把控制权交出来了了
           q1.pop();     //弹出队列的第一个元素,注意,并不会返回被弹出元素的值
    
           if(a->lchild!=NULL)  {a = a->lchild;  q1.push(a->lchild);} ;
           if(a->rchild!=NULL)  {q1.push(a->rchild);};
        }
    
        cout <<"-----------"<<endl;
        void preOrder(BTNode *a);
        preOrder(&a1);
    
        return 0;
    }
    
    void preOrder(BTNode *a)
    {
        if(a==NULL) return;
    
        preOrder(a->lchild);
        preOrder(a->rchild);
        cout << a->data <<endl;
    }
     a2.rchild
  • 相关阅读:
    iOS 之 创建分类
    iOS 之 动画
    iOS 倒出spa文件 打包
    js闭包
    wampserver配置多站点
    js重定向
    php obstart
    php保存远程图片
    php获取前天的昨天的日期
    weixin js接口
  • 原文地址:https://www.cnblogs.com/cs-lcy/p/7103452.html
Copyright © 2011-2022 走看看