如何通过labview创建二叉树并且遍历它的所有结点

如何通过labview创建二叉树并且遍历它的所有结点,第1张

我写了一个二叉树 你给看看 一定能行的我自己用了

#include "stdio.h"

#include "malloc.h"

#include "string.h"

#include "stdlib.h"

#define Max 20 //结点的最大个数

typedef struct BinTNode{

char data

struct BinTNode *lchild,*rchild

}BinTNode,*BinTree //自定义二叉树的结点类型

//定义二叉树的指针

int NodeNum,leaf //NodeNum为结点数,leaf为叶子数

//==========以广义表显示二叉树==============

void DisTree(BinTree T)

{

if(T)

{

printf("%c",T->data)

if((T->lchild)||(T->rchild))

{

if(T->lchild)

{

printf("%c",'(')

DisTree(T->lchild)

}

if(T->rchild)

{

printf("%c",',')

DisTree(T->rchild)

printf("%c",')')

}

}

}

}

//==========基于先序遍历算法创建二叉树==============

//=====要求输入先序序列,其中加入虚结点"#"以示空指针的位置==========

BinTree CreatBinTree(BinTree T)

{

char ch

ch=getchar()

if(ch=='#')

T=NULL

else

{

if(!(T=(BinTNode *)malloc(sizeof(BinTNode))))

printf("Error!")

T->data=ch

T->lchild=CreatBinTree(T->lchild)

T->rchild=CreatBinTree(T->rchild)

}

return T

}

//========NLR 先序遍历=============

void Preorder(BinTree T)

{

if(T)

{

printf("%c",T->data)

Preorder(T->lchild)

Preorder(T->rchild)

}

}

//========LNR 中序遍历===============

void Inorder(BinTree T)

{

if(T){

Inorder(T->lchild)

printf("%c",T->data)

Inorder(T->rchild)

}

}

//==========LRN 后序遍历============

void Postorder(BinTree T)

{

if(T){

Postorder(T->lchild)

Postorder(T->rchild)

printf("%c",T->data)

}

}

//=====采用后序遍历求二叉树的深度、结点数及叶子数的递归算法========

int TreeDepth(BinTree T)

{

int hl,hr,max

if(T){

hl=TreeDepth(T->lchild) //求左深度

hr=TreeDepth(T->rchild) //求右深度

max=hl>hr? hl:hr //取左右深度的最大值

NodeNum=NodeNum+1//求结点数

if(hl==0&&hr==0)

leaf=leaf+1 //若左右深度为0,即为叶子。

return(max+1)

}

else return(0)

}

//====利用"先进先出"(FIFO)队列,按层次遍历二叉树==========

void Levelorder(BinTree T)

{

int front=0,rear=1

BinTNode *cq[Max],*p //定义结点的指针数组cq

cq[1]=T //根入队

while(front!=rear)

{

front=(front+1)%NodeNum

p=cq[front] //出队

printf("%c",p->data)//出队,输出结点的值

if(p->lchild!=NULL){

rear=(rear+1)%NodeNum

cq[rear]=p->lchild//左子树入队

}

if(p->rchild!=NULL){

rear=(rear+1)%NodeNum

cq[rear]=p->rchild//右子树入队

}

}

}

//==========主函数=================

void main()

{

BinTree T,root

int i,depth

printf("\n")

printf("输入完全二叉树的先序序列:")//输入完全二叉树的先序序列,

// 用#代表虚结点,如ABD###CE##F##

root=CreatBinTree(T) //创建二叉树,返回根结点

DisTree(root)

printf("\n")

do //从菜单中选择遍历方式,输入序号。

{

printf("\t********** 菜单 ************\n")

printf("\n")

printf("\t1: 先序遍历\n")

printf("\t2: 中序遍历\n")

printf("\t3: 后序遍历\n")

printf("\t4: 该树的深度,结点数,叶子数\n")

printf("\t5: 层次遍历\n")//按层次遍历之前,先选择4,求出该树的结点数。

printf("\t0: 退出\n")

printf("\t*******************************\n")

scanf("%d",&i)

//输入菜单序号(0-5)

switch(i)

{

case 1: {printf("Print Bin_tree Preorder: ")

Preorder(root) //先序遍历

}break

case 2: {printf("Print Bin_Tree Inorder: ")

Inorder(root) //中序遍历

}break

case 3: {printf("Print Bin_Tree Postorder: ")

Postorder(root) //后序遍历

}break

case 4: {depth=TreeDepth(root)//求树的深度及叶子数

printf("树深=%d 树总结点数=%d",depth,NodeNum)

printf(" 树叶子数=%d",leaf)

}break

case 5: {printf("LevePrint Bin_Tree: ")

Levelorder(root)//按层次遍历

}break

default: exit(1)

}

}while(i>=0&&i<6)

}

labview树形控件获取子项文本方法如下。

1、右键选择字符串与路径选择文件路径输入控件在文件路径输入栏右端浏览选取的所要读取的TXT文件。

2、右键选择字符串与路径选择字符串显示控件。

3、设置完毕后,就会在后面板中出现文件路径与字符串显示两个控件。

4、之后其他的控件均在右键文件I/O中可以找见,分别是图中的打开文件设置文件位置读取文本文件关闭文件,依次连线。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11577204.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-17
下一篇 2023-05-17

发表评论

登录后才能评论

评论列表(0条)

保存