数据结构例程——从根节点到每个叶子节点的路径之逆

2024-03-03 07:08

本文主要是介绍数据结构例程——从根节点到每个叶子节点的路径之逆,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文是数据结构基础系列(6):树和二叉树中第11课时二叉树遍历非递归算法和第12课时层次遍历算法的例程。

问题:设计算法输出从根节点到每个叶子节点的路径之逆。
解法1:利用二叉树后序遍历非递归算法中,每一个叶子节点出现时,栈中从栈顶到栈底,正好是叶子节点到根节点的逆序的性质编写。

[参考解答](btreee.h见算法库)

#include <stdio.h>
#include "btree.h"void AllPath1(BTNode *b)
{BTNode *St[MaxSize];BTNode *p;int flag,i,top=-1;  //栈指针置初值if (b!=NULL){do{while (b!=NULL) //将*b的所有左节点进栈{top++;St[top]=b;b=b->lchild;}p=NULL;flag=1;while (top!=-1 && flag){b=St[top];       //取出当前的栈顶元素if (b->rchild==p){if (b->lchild==NULL && b->rchild==NULL){//若为叶子节点,输出栈中所有节点值for (i=top; i>0; i--)printf("%c->",St[i]->data);printf("%c\n",St[0]->data);}top--;p=b;            //p指向刚访问过的节点}else{b=b->rchild;          //b指向右孩子节点flag=0;}}}while (top!=-1);printf("\n");}
}int main()
{BTNode *b;CreateBTNode(b,"A(B(D,E(H(J,K(L,M(,N))))),C(F,G(,I)))");printf("二叉树b: ");DispBTNode(b);printf("\n");printf("从根节点到每个叶子节点的路径之逆:\n");AllPath1(b);DestroyBTNode(b);return 0;
}

解法2:利用二叉树层次遍历算法的思路解决。

  • 采用非环形顺序队列qu
  • 层次遍历二叉树
  • 将所有已访问过的节点指针进队,并在队列中保存双亲节点的位置。
  • 当找到一个叶子节点时,在队列中通过双亲节点的位置输出根节点到该叶子节点的路径之逆。

[参考解答](btreee.h见算法库)

#include <stdio.h>
#include "btree.h"void AllPath2(BTNode *b)
{struct snode{BTNode *node;   //存放当前节点指针int parent;     //存放双亲节点在队列中的位置} qu[MaxSize];      //定义非环形队列BTNode *q;int front,rear,p;   //定义队头和队尾指针front=rear=-1;      //置队列为空队列rear++;qu[rear].node=b;    //根节点指针进入队列qu[rear].parent=-1; //根节点没有双亲节点while (front!=rear) //队列不为空{front++;        //front是当前节点*q在qu中的位置q=qu[front].node;   //队头出队列,该节点指针仍在qu中if (q->lchild==NULL && q->rchild==NULL){p=front;        //输出*q到根节点的路径序列while (qu[p].parent!=-1){printf("%c->",qu[p].node->data);p=qu[p].parent;}printf("%c\n",qu[p].node->data);}if (q->lchild!=NULL)    //*q节点有左孩子时将其进列{rear++;qu[rear].node=q->lchild;qu[rear].parent=front; //*q的双亲位置为front}if (q->rchild!=NULL)       //*q节点有右孩子时将其进列{rear++;qu[rear].node=q->rchild;qu[rear].parent=front; //*q的双亲位置为front}}
}int main()
{BTNode *b;CreateBTNode(b,"A(B(D,E(H(J,K(L,M(,N))))),C(F,G(,I)))");printf("二叉树b: ");DispBTNode(b);printf("\n");printf("从根节点到每个叶子节点的路径之逆:\n");AllPath2(b);DestroyBTNode(b);return 0;
}

注:在main函数中,创建的用于测试的二叉树如下——
这里写图片描述

这篇关于数据结构例程——从根节点到每个叶子节点的路径之逆的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/768861

相关文章

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

VSCode设置python SDK路径的实现步骤

《VSCode设置pythonSDK路径的实现步骤》本文主要介绍了VSCode设置pythonSDK路径的实现步骤,包括命令面板切换、settings.json配置、环境变量及虚拟环境处理,具有一定... 目录一、通过命令面板快速切换(推荐方法)二、通过 settings.json 配置(项目级/全局)三、

使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)

《使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)》字体设计和矢量图形处理是编程中一个有趣且实用的领域,通过Python的matplotlib库,我们可以轻松将字体轮廓... 目录背景知识字体轮廓的表示实现步骤1. 安装依赖库2. 准备数据3. 解析路径指令4. 绘制图形关键

如何更改pycharm缓存路径和虚拟内存分页文件位置(c盘爆红)

《如何更改pycharm缓存路径和虚拟内存分页文件位置(c盘爆红)》:本文主要介绍如何更改pycharm缓存路径和虚拟内存分页文件位置(c盘爆红)问题,具有很好的参考价值,希望对大家有所帮助,如有... 目录先在你打算存放的地方建四个文件夹更改这四个路径就可以修改默认虚拟内存分页js文件的位置接下来从高级-

一文详解如何查看本地MySQL的安装路径

《一文详解如何查看本地MySQL的安装路径》本地安装MySQL对于初学者或者开发人员来说是一项基础技能,但在安装过程中可能会遇到各种问题,:本文主要介绍如何查看本地MySQL安装路径的相关资料,需... 目录1. 如何查看本地mysql的安装路径1.1. 方法1:通过查询本地服务1.2. 方法2:通过MyS

Python如何调用指定路径的模块

《Python如何调用指定路径的模块》要在Python中调用指定路径的模块,可以使用sys.path.append,importlib.util.spec_from_file_location和exe... 目录一、sys.path.append() 方法1. 方法简介2. 使用示例3. 注意事项二、imp

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

Linux修改pip和conda缓存路径的几种方法

《Linux修改pip和conda缓存路径的几种方法》在Python生态中,pip和conda是两种常见的软件包管理工具,它们在安装、更新和卸载软件包时都会使用缓存来提高效率,适当地修改它们的缓存路径... 目录一、pip 和 conda 的缓存机制1. pip 的缓存机制默认缓存路径2. conda 的缓

Windows系统下如何查找JDK的安装路径

《Windows系统下如何查找JDK的安装路径》:本文主要介绍Windows系统下如何查找JDK的安装路径,文中介绍了三种方法,分别是通过命令行检查、使用verbose选项查找jre目录、以及查看... 目录一、确认是否安装了JDK二、查找路径三、另外一种方式如果很久之前安装了JDK,或者在别人的电脑上,想