数据结构C语言版(李云清)实验7 二叉树
实验7 二叉树
1、编写算法函数void preorder1(bintree t)实现二叉树t的非递归前序遍历。
#include "bintree.h"
char *a="ABC##D#E##F##"; /*扩充二叉树序树t的前序序列*//*函数preorder1()的功能是非递归前序遍历二叉树t,请将函数补充完整并调试运行*/
void preorder1(bintree t)
{seqstack s;init(&s);while ( !empty(&s) || t ){if (t){printf("%c",t->data);push(&s, t);t=t->lchild;}else{t=pop(&s);t=t->rchild;}}
}
int main()
{ bintree t;t=creatbintree(); /*建立二叉树t的存储结构*/printf("二叉树的前序序列为:\n");preorder1(t); /*前序非递归遍历二叉树*/return 0;
}
2、编写算法函数void levelbintree(bintree t),实现二叉树的层次遍历。
#include "bintree.h"
char *a="ABC##D#E##F##"; /*扩充二叉树序树t的前序序列*/
void levelbintree(bintree t)
{bintree queue[100];int f,r;f=0;r=1;if (t){queue[0]=t;while (f<r){t=queue[f++];printf("%c",t->data);if (t->lchild)queue[r++]=t->lchild;if (t->rchild)queue[r++]=t->rchild;}}}
int main()
{ bintree t;t=creatbintree(); /*建立二叉树t的存储结构*/printf("二叉树的层次序列为:\n");levelbintree(t); /*层次遍历二叉树*/return 0;
}
3、编写函数bintree prelist(bintree t),bintree postfirst(bintree t),分别返回二叉树t在前序遍历下的最后一个结点地址和后序遍历下的第一个结点地址。
#include "bintree.h"
char *a="ABC##D##EF#G###"; /*扩充二叉树序树t的前序序列*/
bintree prelast(bintree t) //递归实现
{if (!t)return t; //空树elseif (t->lchild==NULL &&t->rchild==NULL) //树根是唯一的结点return t;elseif (t->rchild) //右子树非空return prelast(t->rchild);elsereturn prelast(t->lchild);
}
bintree prelast1(bintree t) //非递归实现
{bintree p=t;if (p){while (p->lchild || p->rchild ) //p为非叶子if (p->rchild)p=p->rchild;elsep=p->lchild;}return p;
}
bintree postfirst(bintree t)
{ bintree p=t;if (p){while (p->lchild || p->rchild )if (p->lchild)p=p->lchild;elsep=p->rchild;}return p;}int main()
{ bintree t,p,q;t=creatbintree(); /*建立二叉树t的存储结构*/p=prelast(t);q=postfirst(t);if (t!=NULL){ printf("前序遍历最后一个结点为:%c\n",p->data);printf("后序遍历第一个结点为:%c\n",q->data);}else printf("二叉树为空!");return 0;
}
4、假设二叉树采用链式方式存储,t为其根结点,编写一个函数int Depth(bintree t, char x),求值为x的结点在二叉树中的层次。
#include "bintree.h"
char *a="ABC##D##EF#G###"; /*扩充二叉树序树t的前序序列*//*函数Depth,功能:求结点x所在的层次
*/
int Depth(bintree t,char x)
{int m,n;if( !t ) return -1; /*未找到的分支标记为-1*/if( t->data == x ) return 1; /*找到返回1*/m = Depth(t->lchild,x); /*因为没有子树就返回-1,所以没必要考虑是否存在子树*/if( m != -1 ) return m+1; /*找到则加1往上计数*/else{ n = Depth(t->rchild,x);if( n != -1 ) return n+1;else return -1; /*没找到继续返回-1*/}}int main()
{ bintree root;char x;int k=0;root=creatbintree();printf("请输入树中的1个结点值:\n");scanf("%c",&x);k=Depth(root,x);printf("%c结点的层次为%d\n",x,k);
}
5、 试编写一个函数,将一棵给定二叉树中所有结点的左、右子女互换。
#include "bintree.h"
char *a="ABC##D##EF#G###"; /*扩充二叉树序树t的前序序列*/
/*请将本函数补充完整,并进行测试*/
void change(bintree t)
{bintree temp; /*将t的左右结点交换*/if (t){temp = t->lchild;t->lchild = t->rchild;t->rchild = temp;if( t->lchild ) change( t->lchild ); /*交换左子树*/if( t->rchild ) change( t->rchild ); /*交换右子树*/}
}
int main()
{ bintree root;root=creatbintree();change(root);preorder(root);
}
6、试编写一个递归函数bintree buildBintree(char *pre, char *mid, int length),根据二叉树的前序序列pre、中序序列mid和前序序列长度length,构造二叉树的二叉链表存储结构,函数返回二叉树的树根地址。
#include "bintree.h"
#include <string.h>
char *a="";/*大概的原理:前序序列的第一个字符是树的根结点root(比如说是 A ),并且A后面的是左子树的前序序列,然后右子树的前序序列在中序序列中, A 左边的是左子树的中序序列, A 右边是右子树的中序序列
*/
bintree buildBintree(char *pre, char *mid,int length)
{if( length ){/*↓↓以下两行,创建树的根节点*/bintree root = (bintree)malloc(sizeof(binnode));root->data = pre[0];/*↓↓以下三行,将中序序列拆分成【左子树的中序序列】和【右子树的中序序列】*/int i;for(i=0;mid[i] != pre[0];i++) ;mid[i] = '\0';/*↓↓以下两行,递归建立左子树和右子树,同理,将前序序列拆分成【左子树的前序序列】和【右子树的前序序列】*/root->lchild = buildBintree(pre+1,mid,i);root->rchild = buildBintree(pre+i+1,mid+i+1,length-i-1);/*最后return根结点*/return root;}else return NULL;
}int main()
{ bintree root;char pre[100],mid[100];puts("请输入前序序列:");gets(pre);puts("请输入中序序列:");gets(mid);root=buildBintree(pre,mid,strlen(pre));puts("后序序列是:");postorder(root);
}
数据结构C语言版(李云清)实验7 二叉树相关推荐
- 23V3有这种C语言表达式吗,数据结构(C语言版第2版_李云清)习题答案2012-12.doc
数据结构(C语言版第2版_李云清)习题答案2012-12.doc 第 1 章 绪论 1.1 什么是数据结构? [答]:数据结构是指按一定的逻辑结构组成的一批数据,使用某种存储结构将这批数据存储 于计算 ...
- 数据结构c语言版实验报告2,数据结构(C语言版) 实验报告 (2)
<数据结构(C语言版) 实验报告 (2)>由会员分享,可在线阅读,更多相关<数据结构(C语言版) 实验报告 (2)(15页珍藏版)>请在人人文库网上搜索. 1.数据结构(C语言 ...
- 【数据结构C语言版】课程实验-图的应用
数据结构C语言版 - 图的应用 前言: 大二本科计算机科学与技术程序员一枚,总结几篇课后实验内容,希望可以帮助到大家. 软件:Devc++ 实验目的: 通过实验掌握图的基本存储原理,能够利用图模型存储 ...
- 数据结构c语言版第三版实验四答案,数据结构(C语言版)第三四章习题答案
Push( &s, t[i]); while( !EmptyStack( &s)) {// 每弹出一个字符与相应字符比较 temp=Pop (&s); if( temp!=S[ ...
- 数据结构c语言版习题
数据结构c语言版习题 文章目录 第一章 绪论 第二章 线性表 第四章 串 第五章数组和广义表作业 第六章 树与二叉树理论作业 第七章图作业 第八章查找作业 第一章 绪论 一.选择题 1.以下说法正确的 ...
- 逆置单链表c语言程序,(数据结构C语言版)顺序表和单链表的逆置
<(数据结构C语言版)顺序表和单链表的逆置>由会员分享,可在线阅读,更多相关<(数据结构C语言版)顺序表和单链表的逆置(7页珍藏版)>请在人人文库网上搜索. 1.实验1-1顺序 ...
- 以串结构存储c语言版,数据结构C语言版 串的块链存储表示和实现
<数据结构C语言版 串的块链存储表示和实现>由会员分享,可在线阅读,更多相关<数据结构C语言版 串的块链存储表示和实现(13页珍藏版)>请在人人文库网上搜索. 1.*数据结构C ...
- 数据结构c语言版朱战立报告,数据结构(C语言版)
本书是Sedgewick彻底修订和重写的C算法系列的第一本.全书分为四部分,共16章.第一部分"基础知识"(第1-2章)介绍基本算法分析原理.第二部分"数据结构" ...
- c语言第二版课后答案pdf,数据结构(C语言版)第2版习题答案—严蔚敏.pdf
数据结构( C语言版) (第2版) 课后习题答案 李冬梅 2015.3 目 录 第 1 章 绪论 1 第 2 章 线性表 5 第 3 章 栈和队列 14 第 4 章 串.数组和广义表 27 第 5 章 ...
- 数据结构c语言邓红卫答案,数据结构(C语言版)
辽宁省"十二五"普通高等教育本科省级规划教材. 数据结构学习与实验指导(C语言版)(普通高校本科计算机专业特色教材精选·算法与程序设计) ¥30.00定价:¥30.00 /2012 ...
最新文章
- 图像检测中的交并比IoU算法原理
- Android MIPI转LVDS显示屏调试---DSI Tuner安装(1).docx
- error LNK2026: 模块对于 SAFESEH 映像是不安全的
- Mysql中查找并删除重复数据的方法
- mysql8修改密码
- NOI2019凉凉记
- (配置消息转换器) sso单点登入之jsonp改进版
- (一)PC 机与单片机通信(RS232 协议)【800个电子设计大赛资料合集】
- vlan的理解以及华为access、trunk、hybrid三种链路对比
- Android Muti-Window
- 前端基础 互联网 DNS 服务器 浏览器
- HTML5期末大作业:在线电影网站设计——我不是药神电影介绍(4页) HTML+CSS+JavaScript 大二实训大作业HTML源码
- 《区块链技术与应用》学习笔记10——ETH数据结构
- 一起学习C语言:C语言数据类型(二)
- pytorch数据抽样 随机取样
- kubeadm join 添加节点 报错
- 读文件时,将str数据转换为float 报错ValueError: could not convert string to float: ‘.‘
- OpenGL学习(十)天空盒
- Unity WEBGL设置浏览器全屏
- 软件测试中用正交实验法设计测试用例
热门文章
- 迅雷离线配合Internet Download Manager下载ED2K链接
- 1362: [蓝桥杯2018初赛]第几个幸运数(简单题)
- 百度的专业检索方法(我们所不知道的搜索语法)
- 可!!Win10禁用驱动程序强制签名
- 【LeetCode】723. Candy Crush 解题报告 (C++)
- 海思平台上USB WIFI的移植与局域网无线调试和视频流预览-第5/11季视频课程-朱有鹏-专题视频课程...
- DD-WRT 的优点
- 阿里云服务器高主频内存型hfr7磁盘I/O性能表
- 201915 天融信防火墙TopGate500初探
- 开发游戏需要什么知识