博客
关于我
数据结构 &二叉树(二)
阅读量:783 次
发布时间:2019-03-25

本文共 993 字,大约阅读时间需要 3 分钟。

首先,我们需要设计二叉树的结构,并使用特殊符号来表示节点的不同部分。通过宏定义和数据类型的重定义,我们可以清晰地展示二叉树节点的结构,包括其左孩子、右孩子以及数据域。

二叉树的定义为:

  • 结构体 BtNode 包含三个成员:
    • leftchild,指向左孩子节点
    • rightchild,指向右孩子节点
    • data,存储节点的数据

遍历二叉树的核心在于按照特定的顺序访问每个节点。树的遍历是一种访问树结构的方式,要求每个节点仅访问一次。常见的遍历方式包括:

  • 前序遍历:先访问根节点,随后遍历左、右子树。
  • 中序遍历:先访问左子树,最后访问根节点,随后遍历右子树。
  • 后序遍历:先遍历左、右子树,最后访问根节点。
  • 基于以上规则,我们可以设计前序、中序以及后序遍历的代码。以下为二叉树节点的定义及遍历代码:

    typedef struct BtNode {    struct BtNode* leftchild;    struct BtNode* rightchild;    char data;} BtNode;

    中序遍历代码

    void InOrder(BtNode* p) {    if (p != NULL) {        InOrder(p->leftchild);        printf("%c ", p->data);        InOrder(p->rightchild);    }}

    前序遍历代码

    void FrontOrder(BtNode* p) {    if (p != NULL) {        printf("%c ", p->data);        FrontOrder(p->leftchild);        FrontOrder(p->rightchild);    }}

    后序遍历代码

    void EndOrder(BtNode* p) {    if (p != NULL) {        EndOrder(p->leftchild);        EndOrder(p->rightchild);        printf("%c ", p->data);    }}

    通过以上代码,我们可以实现对给定二叉树的三种不同遍历方式:中序、前序和后序。每种遍历方式都有其独特的应用场景,并且可以根据具体需求进行调整和优化。

    转载地址:http://cmtuk.baihongyu.com/

    你可能感兴趣的文章
    Vue过渡 & 动画---vue工作笔记0014
    查看>>
    Netty 异步任务调度与异步线程池
    查看>>
    Netty 的 Handler 链调用机制
    查看>>
    Netty 编解码器详解
    查看>>
    Netty 解决TCP粘包/半包使用
    查看>>
    Netty 调用,效率这么低还用啥?
    查看>>
    Netty+Protostuff实现单机压测秒级接收35万个对象实践经验分享
    查看>>
    Netty+SpringBoot+FastDFS+Html5实现聊天App详解(一)
    查看>>
    netty--helloword程序
    查看>>
    Netty5.x 和3.x、4.x的区别及注意事项(官方翻译)
    查看>>
    netty——bytebuf的创建、内存分配与池化、组成、扩容规则、写入读取、内存回收、零拷贝
    查看>>
    netty——Channl的常用方法、ChannelFuture、CloseFuture
    查看>>
    netty——Future和Promise的使用 线程间的通信
    查看>>
    netty——Handler和pipeline
    查看>>
    Vue输出HTML
    查看>>
    netty——黏包半包的解决方案、滑动窗口的概念
    查看>>
    Netty中Http客户端、服务端的编解码器
    查看>>
    Netty中使用WebSocket实现服务端与客户端的长连接通信发送消息
    查看>>
    Netty中实现多客户端连接与通信-以实现聊天室群聊功能为例(附代码下载)
    查看>>
    Netty中的组件是怎么交互的?
    查看>>