资源简介
二叉树的C语言实现,实现二叉树基本功能,建树、遍历、左右子树交换等功能。
代码片段和文件信息
#include
#include
#include
#define MAXSIZE 100
using namespace std;
struct TreeNode
{
char data;
TreeNode *lchild*rchild;
};
void CreateBiTree(TreeNode *&char []); //用字符串建树
void preorder(TreeNode *&); //二叉树递归遍历前序
void inorder(TreeNode *&); //二叉树递归遍历中序
void postorder(TreeNode *&); //二叉树递归遍历后序
int count(TreeNode *&); //叶子计数
int TreeHigh(TreeNode *&); //递归求树高
void Exchange(TreeNode *&); //二叉树左右子树交换
void CopyTree(TreeNode *&TreeNode *&); //二叉树拷贝目的二叉树t源二叉树s
void ReadyStack(void); //栈初实例化
void preorder1(TreeNode *); //非递归的前序遍历(利用栈实现)
void inorder1(TreeNode *); //非递归的中序遍历(利用栈实现)
void postorder1(TreeNode *); //非递归的后序遍历(利用栈实现)
void set(TreeNode *&char []char []intintintint);//有前序和中序遍历序列,用递归方法建树
int main(void)
{
char *s;
s=“ABC**DE*G**F***“;
// cout<<“按先序遍历序列遍历二叉树,其中空用*号代替:“;
// cin>>s;
TreeNode *tree;
cout<<“用前序字符串序列 “< CreateBiTree(trees);
cout< cout< cout< cout< cout< TreeNode *ctree;
CopyTree(ctreetree);
cout< cout< cout< cout< cout< Exchange(ctree);
cout< cout< cout< char pre[]=“ABCDEGF“; //前序遍历后数组
char in[]=“CBEGDFA“; //中序遍历后数组
cout<<“前序遍历数组:“< cout<<“中序遍历数组:“< TreeNode *top;
set(topprein0strlen(pre)-10strlen(in)-1); //重建二叉树
cout<<“重建二叉树后序遍历结果:“; postorder1(top);
cout< system(“PAUSE“);
return 0;
}
void CreateBiTree(TreeNode *&pchar ar[]) //建树
{ char ch;
static int i;
ch=ar[i++];
if(ch!=‘*‘)
{ p=new TreeNode;
p->data=ch;
CreateBiTree(p->lchildar);
CreateBiTree (p->rchildar);
}
else p=NULL;
}
void preorder(TreeNode *&p) //二叉树递归遍历前序
{
if(p)
{ cout<data;
preorder(p->lchild);
preorder(p->rchild);
}
}
void inorder(TreeNode *&p) //二叉树递归遍历中序
{
if(p)
{ inorder (p->lchild);
cout<data;
inorder (p->rchild);
}
}
void postorder(TreeNode *&p) //二叉树递归遍历后序
{
if(p)
{ postorder (p->lchild);
postorder (p->rchild);
cout<data;
}
}
int count(TreeNode *&p) //叶子计数
{
int mn;
if(p)
{ m=count - 上一篇:DES加密码算法MFC类实现
- 下一篇:DVB编程实现TS流解析
相关资源
- GD32通过规则组寄存器 DMA获取多组AD
- 基于MFC的TCP调试助手源码95706
- 国际象棋的qt源代码
- 操作系统c语言模拟文件管理系统844
- C语言开发实战宝典
- C++中头文件与源文件的作用详解
- 基于mfc的多线程文件传输
- C++多线程网络编程Socket
- VC++ 多线程文件读写操作
- C语言代码高亮html输出工具
- 猜数字游戏 c语言代码
- C语言课程设计
- 数字电位器C语言程序
- CCS FFT c语言算法
- 使用C语言编写的病房管理系统
- 通信过程中的RS编译码程序(c语言)
- 利用C++哈希表的方法实现电话号码查
- 计算机二级C语言上机填空,改错,编
- 用回溯法解决八皇后问题C语言实现
- 移木块游戏,可以自编自玩,vc6.0编写
- 简易教务管理系统c语言开发文档
- 操作系统课设 读写者问题 c语言实现
- 小波变换算法 c语言版
- C流程图生成器,用C语言代码 生成C语
- 3des加密算法C语言实现
- 简单的C语言点对点聊天程序
- 单片机c语言源程序(51定时器 八个按
- C++纯文字DOS超小RPG游戏
- 个人日常财务管理系统(C语言)
- MFC数字钟(基于VC6.0)
川公网安备 51152502000135号
评论
共有 条评论