zoukankan      html  css  js  c++  java
  • 先序非递归建立二叉树

      大二这么久了,第一个学期课程实在太少,而且全都不是CS的专业课,无奈,若是自己不勤奋一点,过了半年,用不到半年,就又变回小白了。所以自己最近也在重新巩固数据结构的知识。刚好看到二叉树这里,觉得二叉树应用广泛,复习的比较细致。

      刚开始就是二叉树的建立了,大多数地方都是先序的递归创建,于是便想着试试非递归的代码,倒腾了个把小时,基本上弄出代码了,本渣渣水平有限,有错误的地方,望路过的大神不吝赐教~~不胜感激!

      主要的思路是:

              按照先序的顺序输入二叉树,若是遇到空子树,用字符‘#‘表示,例如

    左图:AB#D##CE###
     
     
       ( 1)若第一次输入就是’#‘,则创建的是空树。
      (2)每次创建一个新的结点p,看栈顶元素的flag,若为0,则取出(不出栈)栈顶指针R,并将其flag修改为1.R->child=p;
                          若flag本身就是1,则直接取栈顶(出栈)!R-rchild=p;
           然后将p入栈。入栈的flag初始值是0;
      (3)当栈为空时,二叉树就建好了。
    代码:
     1 #include<stdio.h>
     2 #include<iostream>
     3 #include<malloc.h>
     4 using namespace std;
     5 typedef struct BiTNode
     6 {
     7     char c;
     8     struct BiTNode *lchild,*rchild;
     9 }BiTNode,*BiTree;
    10 typedef struct
    11 {
    12     BiTree x;
    13     int flag;
    14 }snode;
    15 typedef struct
    16 {
    17     snode sdata[100];
    18     int top;
    19 }Stack;
    20 int Empty(Stack s)
    21 {
    22     if(s.top==-1) return 1;
    23     else return 0;
    24 }
    25 void Pop(Stack &s,BiTree R)          //取栈顶元素,flag=1标志已经被取过一次
    26 {
    27     R=s.sdata[s.top].x;
    28     s.sdata[s.top].flag=1;
    29 }
    30 void Out(Stack &s,BiTree R)         //取栈顶元素,并且栈顶元素出栈
    31 {
    32     R=s.sdata[s.top].x;
    33     s.top--;
    34 }
    35 void In(Stack &s,BiTree R)          //指针入栈,flag=0标志从未被取过
    36 {
    37     s.top++;
    38     s.sdata[s.top].x=R;
    39     s.sdata[s.top].flag=0;
    40 }
    41 void CreateBiTree(BiTree T)
    42 {
    43     char ch;
    44     Stack s;
    45     T=NULL;
    46     s.top=-1;
    47     BiTree R=T,p;
    48     do
    49     {
    50         cin>>ch;
    51         if(Empty(s)&&ch=='#')
    52             return;
    53         else if(ch!='#')
    54         {
    55             p=(BiTree)malloc(sizeof(BiTNode));
    56             p->c=ch;
    57             if(Empty(s))
    58             {
    59                 T=p;
    60                 R=p;
    61             }
    62             else if(s.sdata[s.top].flag==0)
    63             {
    64                 Pop(s,R);
    65                 R->lchild=p;
    66             }
    67             else
    68             {
    69                 Out(s,R);
    70                 R->rchild=p;
    71             }
    72             In(s,p);
    73         }
    74         else
    75         {
    76             if(s.sdata[s.top].flag==0)
    77             {
    78                 Pop(s,R);
    79 
    80                 R->lchild=NULL;
    81             }
    82             else
    83             {
    84                 Out(s,R);
    85                 R->rchild=NULL;
    86             }
    87         }
    88     }while(s.top!=-1);
    89 }
    90 int main()
    91 {
    92     BiTree T;
    93     CreateBiTree(T);
    94 }

  • 相关阅读:
    MySql给表中某字段插入随机数
    MySql 基本语法_数据操作
    thinkphp中模板继承
    thinkphp中模块和操作映射
    如何让ThinkPHP的模板引擎达到最佳效率
    ThinkPHP访问不存在的模块跳到404页面
    thinkphp中I方法
    thinkphp中field方法
    thinkphp中F方法
    thinkphp中where方法
  • 原文地址:https://www.cnblogs.com/Elaine-DWL/p/4859546.html
Copyright © 2011-2022 走看看