标签:复习 ElemType bt item CreateBinTree 二叉树 BinTreeNode 数据结构 BinTree
1、递归实现二叉树的定义以及创建
#include<stdio.h> #include<assert.h> #include<malloc.h> #define ElemType char typedef struct BinTreeNode { ElemType data; struct BinTreeNode *leftchild; struct BinTreeNode *rightchild; }BinTreeNode; typedef struct BinTree { BinTreeNode *root; ElemType refvalue; }BinTree; void InitBinTree(BinTree *bt,ElemType ref) { bt->root = NULL; bt->refvalue = ref; } //创建二叉树 void CreateBinTree_1(BinTree *bt, BinTreeNode **t) { ElemType item; scanf("%c",&item); if(item == bt->refvalue) (*t) = NULL; else{ (*t) = (BinTreeNode*)malloc(sizeof(BinTreeNode)); assert((*t) != NULL); (*t)->data = item; CreateBinTree_1(bt,&((*t)->leftchild)); CreateBinTree_1(bt,&((*t)->rightchild)); } } void CreateBinTree_1(BinTree *bt) { CreateBinTree_1(bt,&(bt->root)); } void CreateBinTree_2(BinTree *bt, BinTreeNode *&t) { ElemType item; scanf("%c",&item); if(item == bt->refvalue) t = NULL; else{ t = (BinTreeNode*)malloc(sizeof(BinTreeNode)); assert(t != NULL); t->data = item; CreateBinTree_2(bt,t->leftchild); CreateBinTree_2(bt,t->rightchild); } } void CreateBinTree_2(BinTree *bt) { CreateBinTree_2(bt,bt->root); } int main() { BinTree mytree; InitBinTree(&mytree,'#'); CreateBinTree_2(&mytree); return 0; }
标签:复习,ElemType,bt,item,CreateBinTree,二叉树,BinTreeNode,数据结构,BinTree 来源: https://www.cnblogs.com/lx06/p/16444241.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。