C语言建立二叉树

    技术2025-12-29  8

    #include<stdio.h> #include<malloc.h> #define MAXNODE 50 #define MaxSize 50 typedef int ElemType; typedef struct node { ElemType data; struct node *lchild; struct node *rchild; }BTNode; //初始化 void InitBTree(BTNode *&T) { T=NULL; } //创建二叉树 BTNode *CreateBTNode(char *str) { BTNode *St[MaxSize],*p=NULL,*T; int top=-1,tag,j=0; char ch; T=NULL; /*建立的二叉树初始时为空*/ ch=str[j]; while (ch!='\0') /*str未扫描完时循环*/ { switch(ch) { case '(':top++;St[top]=p;tag=1; break; case ')':top--;break; case ',':tag=2; break; default: p=(BTNode *)malloc(sizeof(BTNode)); p->data=ch; p->lchild=p->rchild=NULL; if (T==NULL) /*p为二叉树的根结点*/ T=p; else /*已建立二叉树根结点*/ { switch(tag) { case 1:St[top]->lchild=p;break; case 2:St[top]->rchild=p;break; } } } j++;ch=str[j]; } return T; } //查找结点 BTNode *FindNode(BTNode *T,ElemType x) { BTNode *p; if (T==NULL) return NULL; else if (T->data==x) return T; else { p=FindNode(T->lchild,x); if (p!=NULL) return p; else return FindNode(T->rchild,x); } } BTNode *LchildNode(BTNode *p) { return p->lchild; } BTNode *RchildNode(BTNode *p) { return p->rchild; } //求高度 int BTNodeDepth(BTNode *T) { int lchilddep,rchilddep; if (T==NULL) return(0); /*空树的高度为0*/ else { lchilddep=BTNodeDepth(T->lchild); /*求左子树的高度为lchilddep*/ rchilddep=BTNodeDepth(T->rchild); /*求右子树的高度为rchilddep*/ return(lchilddep>rchilddep)?(lchilddep+1):(rchilddep+1); } } //访问二叉树结点 void visite (BTNode *T) { if(T==NULL) printf("The node does not exist"); else printf("%c",T->data); } //横向输出二叉树 void PrintBiTree(BTNode *T, int level) /*level设初始值为0*/ { if(T!= NULL) { PrintBiTree(T->rchild, level+1); if(level != 0) /*走过4*(level-1)个空格*/ { for(int i=0; i <4*(level-1); i++) { printf("%s"," "); } printf("%s","---"); /*输出横线*/ } visite(T); /*输出结点的数据元素值*/ printf("\n"); PrintBiTree(T->lchild,level+1); } } //中序遍历 void InOrderTraverse(BTNode *T) { if (T!=NULL) { InOrderTraverse(T->lchild); /*递归访问左子树*/ visite(T); /*访问根结点*/ InOrderTraverse(T->rchild); /*递归访问右子树*/ } } //层次遍历 void LevelTraverse(BTNode *T) { BTNode *p; BTNode *qu[MaxSize]; /*定义环形队列,存放结点指针*/ int front,rear; /*定义队头和队尾指针*/ front=rear=-1; /*置队列为空队列*/ rear++; qu[rear]=T; /*根结点指针进入队列*/ while (front!=rear) /*队列不为空*/ { front=(front+1)%MaxSize; p=qu[front]; /*队头出队列*/ visite(p); /*访问结点*/ if (p->lchild!=NULL) /*有左孩子时将其进队*/ { rear=(rear+1)%MaxSize; qu[rear]=p->lchild; } if (p->rchild!=NULL) /*有右孩子时将其进队*/ { rear=(rear+1)%MaxSize; qu[rear]=p->rchild; } } } void printfBT(BTNode *T) { if(T!=NULL) { printf("%c",T->data); if(T->lchild!=NULL||T->rchild!=NULL) { printf("("); if(T->rchild=NULL) { printf(","); } { printfBT(T->rchild); printf(")"); } } } }

    阿里云建站,品牌保障之选 伴随着互联网的发展,为了适应社会的发展趋势,企业建站已经成为一个企 业放眼长远发展中必不可少的一环,但是网站开发与制作却成为企业迫切解决的 难题,尽管市面上有大量的建站服务平台,但阿里云建站却能在众多建站平台之 中脱颖而出。 阿里云创立于2009年,阿里巴巴集团旗下公司,是全球领先的云计算及人 工智能科技公司,为200多个国家和地区的企业、开发者和政府机构提供服务。 阿里云建站致力于集成阿里云资源,为企业提供安全、可靠的建站服务,已经超 过50万企业用户建站都选阿里云。 要确保网站顺利上线,除了搭建网站外,还需要购买域名、备案、域名解析。 如果您没有选择阿里云建站,您还需要找单独的服务商完成这些事项,费钱又费 力。选择阿里云建站就不一样了,阿里云为广大用户提供域名注册、全自助在线 免费备案、同时支持阿里云域名一键解析,一站式服务让网站上线更快速。 据了解,阿里云建站产品还支持退款服务,模板建站产品5天无理由退换, 定制建站产品不满意全额退,超级贴心。 阿里云建站主推2款建站产品: 【云·速成美站】模板建站,可视化操作自己动手建网站,售价500-2998元 【云·企业官网】设计师量身设计,一对一服务,专业省心之选,售价4980-10480 元 现在点击链接购买还有优惠哦,还等什么行动起来! https://www.aliyun.com/minisite/goods?userCode=zuniyo9i

    Processed: 0.014, SQL: 9