数据结构——二叉树的层序遍历

算法设计
二叉树的层序遍历用到的是队列,创建二叉树时用的是递归的方法。在层序遍历时用队列来存储结点。

层序遍历二叉树:
首先,让根结点入队,然后执行一个循环,条件是:队列不为空。也就是队列不为空时,令一个结点出队,然后输出该结点的data中的数据,并判断该结点的左右孩子是否存在,若存在,则将它们分别入队。再次执行该循环,直到队列为空,结束。

代码:

#include "stdio.h"
#include "stdlib.h"

#define MAXQSIZE 100   //最大队列长度
typedef char SElemType;
typedef struct TreeNode{
    SElemType data;
    struct TreeNode *lchild,*rchild;
}TreeNode,*BiTree;

//创建树
int CreateTree(BiTree *root){ 
    char ch;
    scanf("%c",&ch);
    getchar();
    if(ch=='#'){
        *root=NULL;
    }else{
        *root=(TreeNode *)malloc(sizeof(TreeNode));
        if(!*root)
            exit(-1);
        (*root)->data=ch;
        CreateTree(&((*root)->lchild));
        CreateTree(&((*root)->rchild));
    }
    return 0;
}

typedef struct{
    BiTree *base;
    int front;   //头指针
    int rear;    //尾指针
}SqQueue;

//创建循环队列
int InitQueue(SqQueue *q){
    q->base=(BiTree *)malloc(MAXQSIZE * sizeof(BiTree));
    if(!q->base)
        exit(0);   //分配失败
    q->front=0;
    q->rear=0;
    return 1;
}

//返回队列q的元素个数
int QueueLength(SqQueue q){    
    return (q.rear-q.front+MAXQSIZE)%MAXQSIZE;
}

//向q队尾插入元素
int EnQueue(SqQueue *q,BiTree e){
    if((q->rear+1)%MAXQSIZE==q->front)  //队列满
        return 0;
    q->base[q->rear]=e;
    q->rear=(q->rear+1)%MAXQSIZE;
    return 1;
}

//删除q的队首元素,用e返回其值
int DeQueue(SqQueue *q,BiTree *e){
    if(q->front==q->rear)   //队列为空
        return 0;
    *e=q->base[q->front];
    q->front=(q->front+1)%MAXQSIZE;
    return 1;
}

//队列判空
int QueueEmpty(SqQueue *q){
    if(q->front==q->rear)
        return 1;
    else
        return 0;
}

//队列判满
int QueueFill(SqQueue *q){
    if((q->rear+1)%MAXQSIZE==q->front)
        return 1;
    else
        return 0;
}

//层序遍历
void seOrder(BiTree tree){   
    SqQueue q;
    BiTree e;
    InitQueue(&q);
    BiTree p=tree;
    if(p->lchild!=NULL||p->rchild!=NULL)
        EnQueue(&q,p);
    while(!QueueEmpty(&q)){
        DeQueue(&q,&e);
        printf("%c ",e->data);
        if(e->lchild!=NULL){
            EnQueue(&q,e->lchild);
        }
        if(e->rchild!=NULL){
            EnQueue(&q,e->rchild);
        }
    }
}
int main(){
    BiTree tree;
    CreateTree(&tree);
    printf("\n层序遍历:");
    seOrder(tree);
    system("pause");
    return 0;
}
  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现二叉树层序遍历需要用到队列这一数据结构,具体实现步骤如下: 1. 定义一个队列结构体,并实现队列的基本操作,包括入队、出队、队列是否为空等。 ``` typedef struct QueueNode { TreeNode *val; struct QueueNode *next; } QueueNode; typedef struct { QueueNode *front; QueueNode *rear; int size; } Queue; Queue *createQueue() { Queue *q = (Queue*)malloc(sizeof(Queue)); q->front = q->rear = NULL; q->size = 0; return q; } bool isEmpty(Queue *q) { return q->size == 0; } void enqueue(Queue *q, TreeNode *val) { QueueNode *newNode = (QueueNode*)malloc(sizeof(QueueNode)); newNode->val = val; newNode->next = NULL; if (isEmpty(q)) { q->front = q->rear = newNode; } else { q->rear->next = newNode; q->rear = newNode; } q->size++; } TreeNode *dequeue(Queue *q) { if (isEmpty(q)) { return NULL; } QueueNode *node = q->front; TreeNode *val = node->val; q->front = q->front->next; if (q->front == NULL) { q->rear = NULL; } free(node); q->size--; return val; } ``` 2. 实现二叉树层序遍历,使用队列来存储当前层的节点,并逐层遍历。 ``` void levelOrder(TreeNode *root) { if (root == NULL) { return; } Queue *q = createQueue(); enqueue(q, root); while (!isEmpty(q)) { int levelSize = q->size; for (int i = 0; i < levelSize; i++) { TreeNode *node = dequeue(q); printf("%d ", node->val); if (node->left != NULL) { enqueue(q, node->left); } if (node->right != NULL) { enqueue(q, node->right); } } printf("\n"); } } ``` 以上代码实现了二叉树层序遍历,可以通过以下测试代码进行测试: ``` int main() { TreeNode *root = createTree(); printf("层序遍历结果:\n"); levelOrder(root); return 0; } ``` 其中,`createTree()` 是创建一个二叉树的函数,可以根据需要自行实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值