实验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 二叉树相关推荐

  1. 23V3有这种C语言表达式吗,数据结构(C语言版第2版_李云清)习题答案2012-12.doc

    数据结构(C语言版第2版_李云清)习题答案2012-12.doc 第 1 章 绪论 1.1 什么是数据结构? [答]:数据结构是指按一定的逻辑结构组成的一批数据,使用某种存储结构将这批数据存储 于计算 ...

  2. 数据结构c语言版实验报告2,数据结构(C语言版) 实验报告 (2)

    <数据结构(C语言版) 实验报告 (2)>由会员分享,可在线阅读,更多相关<数据结构(C语言版) 实验报告 (2)(15页珍藏版)>请在人人文库网上搜索. 1.数据结构(C语言 ...

  3. 【数据结构C语言版】课程实验-图的应用

    数据结构C语言版 - 图的应用 前言: 大二本科计算机科学与技术程序员一枚,总结几篇课后实验内容,希望可以帮助到大家. 软件:Devc++ 实验目的: 通过实验掌握图的基本存储原理,能够利用图模型存储 ...

  4. 数据结构c语言版第三版实验四答案,数据结构(C语言版)第三四章习题答案

    Push( &s, t[i]); while( !EmptyStack( &s)) {// 每弹出一个字符与相应字符比较 temp=Pop (&s); if( temp!=S[ ...

  5. 数据结构c语言版习题

    数据结构c语言版习题 文章目录 第一章 绪论 第二章 线性表 第四章 串 第五章数组和广义表作业 第六章 树与二叉树理论作业 第七章图作业 第八章查找作业 第一章 绪论 一.选择题 1.以下说法正确的 ...

  6. 逆置单链表c语言程序,(数据结构C语言版)顺序表和单链表的逆置

    <(数据结构C语言版)顺序表和单链表的逆置>由会员分享,可在线阅读,更多相关<(数据结构C语言版)顺序表和单链表的逆置(7页珍藏版)>请在人人文库网上搜索. 1.实验1-1顺序 ...

  7. 以串结构存储c语言版,数据结构C语言版 串的块链存储表示和实现

    <数据结构C语言版 串的块链存储表示和实现>由会员分享,可在线阅读,更多相关<数据结构C语言版 串的块链存储表示和实现(13页珍藏版)>请在人人文库网上搜索. 1.*数据结构C ...

  8. 数据结构c语言版朱战立报告,数据结构(C语言版)

    本书是Sedgewick彻底修订和重写的C算法系列的第一本.全书分为四部分,共16章.第一部分"基础知识"(第1-2章)介绍基本算法分析原理.第二部分"数据结构" ...

  9. c语言第二版课后答案pdf,数据结构(C语言版)第2版习题答案—严蔚敏.pdf

    数据结构( C语言版) (第2版) 课后习题答案 李冬梅 2015.3 目 录 第 1 章 绪论 1 第 2 章 线性表 5 第 3 章 栈和队列 14 第 4 章 串.数组和广义表 27 第 5 章 ...

  10. 数据结构c语言邓红卫答案,数据结构(C语言版)

    辽宁省"十二五"普通高等教育本科省级规划教材. 数据结构学习与实验指导(C语言版)(普通高校本科计算机专业特色教材精选·算法与程序设计) ¥30.00定价:¥30.00 /2012 ...

最新文章

  1. 图像检测中的交并比IoU算法原理
  2. Android MIPI转LVDS显示屏调试---DSI Tuner安装(1).docx
  3. error LNK2026: 模块对于 SAFESEH 映像是不安全的
  4. Mysql中查找并删除重复数据的方法
  5. mysql8修改密码
  6. NOI2019凉凉记
  7. (配置消息转换器) sso单点登入之jsonp改进版
  8. (一)PC 机与单片机通信(RS232 协议)【800个电子设计大赛资料合集】
  9. vlan的理解以及华为access、trunk、hybrid三种链路对比
  10. Android Muti-Window
  11. 前端基础 互联网 DNS 服务器 浏览器
  12. HTML5期末大作业:在线电影网站设计——我不是药神电影介绍(4页) HTML+CSS+JavaScript 大二实训大作业HTML源码
  13. 《区块链技术与应用》学习笔记10——ETH数据结构
  14. 一起学习C语言:C语言数据类型(二)
  15. pytorch数据抽样 随机取样
  16. kubeadm join 添加节点 报错
  17. 读文件时,将str数据转换为float 报错ValueError: could not convert string to float: ‘.‘
  18. OpenGL学习(十)天空盒
  19. Unity WEBGL设置浏览器全屏
  20. 软件测试中用正交实验法设计测试用例

热门文章

  1. 迅雷离线配合Internet Download Manager下载ED2K链接
  2. 1362: [蓝桥杯2018初赛]第几个幸运数(简单题)
  3. 百度的专业检索方法(我们所不知道的搜索语法)
  4. 可!!Win10禁用驱动程序强制签名
  5. 【LeetCode】723. Candy Crush 解题报告 (C++)
  6. 海思平台上USB WIFI的移植与局域网无线调试和视频流预览-第5/11季视频课程-朱有鹏-专题视频课程...
  7. DD-WRT 的优点
  8. 阿里云服务器高主频内存型hfr7磁盘I/O性能表
  9. 201915 天融信防火墙TopGate500初探
  10. 开发游戏需要什么知识