首页 > 其他 > 详细

二叉树的层次遍历和(叶子)节点

时间:2017-11-02 12:31:45      阅读:215      评论:0      收藏:0      [点我收藏+]
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define size 100
#define resize 10 
typedef struct Bitnode{        //定义结点
    char data;
    struct Bitnode *lchild,*rchild;
}Bitnode,*Bitree;

typedef struct {             //定义队列
    Bitree *base;
    int front;
    int rear;
}Queue;

int count=0;

void Initqueue(Queue &Q)            //建立队列
{
    Q.base=(Bitree*)malloc(size*sizeof(Queue));
    if(!Q.base)
        exit(0);
    Q.front=Q.rear=0;    
}

Bitree Enqueue(Queue &Q,Bitree e)        //入队列
{
    if((Q.rear+1)%size==Q.front)        //循环队列
        return 0;
    Q.base[Q.rear]=e;
    Q.rear=(Q.rear+1)%size;
    return e;
}

int Queueempty(Queue Q)          //队列的判空操作
{
    if(Q.front==Q.rear)
        return 1;
    return 0;
}

void Dequeue(Queue &Q,Bitree &e)          //出队列
{
    
    if(Q.front==Q.rear)
        exit(0);
    e=Q.base[Q.front];
    Q.front=(Q.front+1)%size;
}
void Createbitree(Bitree &bt)
{
    //建立二叉树的二叉链表
    char ch;
    ch=getchar();
    if(ch==#)
        bt=NULL;
    else
    {
        bt=(Bitree)malloc(sizeof(Bitnode));
        bt->data=ch;
        bt->lchild=bt->rchild=NULL;
        count++;
        Createbitree(bt->lchild);
        Createbitree(bt->rchild);    
    } 
}

void Levelordertraverse(Bitree bt)       //二叉树的层次遍历
{
    Bitree p;
    Queue Q;
    if(bt)
    {
        Initqueue(Q);
        Enqueue(Q,bt);
        while(!Queueempty(Q))
        {
            Dequeue(Q,p);
            printf("%c ",p->data);
            if(p->lchild)
                Enqueue(Q,p->lchild);
            if(p->rchild)
                Enqueue(Q,p->rchild);
        }
    }
    printf("\n");
}

void Leafnode(Bitree bt)        //找叶子结点
{
    Bitree p;
    Queue Q;
    if(bt)
    {
        Initqueue(Q);
        Enqueue(Q,bt);
        while(!Queueempty(Q))
        {
            
            Dequeue(Q,p);
            if(p->lchild||p->rchild)
            {
                if(p->lchild)
                Enqueue(Q,p->lchild);
                 if(p->rchild)
                Enqueue(Q,p->rchild);
            }
            else
            printf("%c ",p->data);
        }
    }
    printf("\n");
}

int main()
{
    Bitree bt;
    Createbitree(bt);
    printf("层次遍历二叉树:\n");
    Levelordertraverse(bt); 
    printf("输出叶子结点:\n");
    Leafnode(bt);
    printf("输出结点总数:%d\n",count);
    return 0;
}

//ABD###CE##F##

 

二叉树的层次遍历和(叶子)节点

原文:http://www.cnblogs.com/linxiaojie517/p/7771477.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!