为了正常的体验网站,请在浏览器设置里面开启Javascript功能!

树的插入

2018-02-20 7页 doc 20KB 57阅读

用户头像

is_083599

暂无简介

举报
树的插入树的插入 #include #include #include #include /* EOF(=^Z或F6),NULL */ #define TRUE 1 #define FALSE 0 #define OK 1 #define ERROR 0 typedef int Status; /* Status是函数的类型,其值是函数结果状态代码,如OK等 */ #if CHAR typedef char TElemType; TElemType Nil=' '; /* 设字符型以空格符为空 */ #els...
树的插入
树的插入 #include #include #include #include /* EOF(=^Z或F6),NULL */ #define TRUE 1 #define FALSE 0 #define OK 1 #define ERROR 0 typedef int Status; /* Status是的类型,其值是函数结果状态代码,如OK等 */ #if CHAR typedef char TElemType; TElemType Nil=' '; /* 设字符型以空格符为空 */ #else typedef int TElemType; TElemType Nil=0; /* 设整型以0为空 */ #endif #define MAX_TREE_SIZE 100 /* 二叉树的最大结点数 */ typedef TElemType SqBiTree[MAX_TREE_SIZE]; /* 0号单元存储根结点 */ typedef struct { 按满二叉树计算) */ int level,order; /* 结点的层,本层序号( }position; Status InitBiTree(SqBiTree T) { /* 构造空二叉树T。因为T是固定数组,不会改变,故不需要& */ int i; for(i=0;i
示空结点,结点数?%d:\n",MAX_TREE_SIZE); gets(s); /* 输入字符串 */ l=strlen(s); /* 求字符串的长度 */ for(;i=0;i--) /* 找到最后一个结点 */ if(T[i]!=Nil) break; i++; /* 为了便于计算 */ do j++; while(i>=pow(2,j)); return j; } TElemType Value(SqBiTree T,position e) { /* 初始条件: 二叉树T存在,e是T中某个结点(的位置) */ /* 操作结果: 返回处于位置e(层,本层序号)的结点的值 */ return T[(int)pow(2,e.level-1)+e.order-2]; } void Move(SqBiTree q,int j,SqBiTree T,int i) /* InsertChild()用到。加 */ { /* 把从q的j结点开始的子树移为从T的i结点开始的子树 */ if(q[2*j+1]!=Nil) /* q的左子树不空 */ Move(q,(2*j+1),T,(2*i+1)); /* 把q的j结点的左子树移为T的i结点的左子树 */ */ if(q[2*j+2]!=Nil) /* q的右子树不空 Move(q,(2*j+2),T,(2*i+2)); /* 把q的j结点的右子树移为T的i结点的右子树 */ T[i]=q[j]; /* 把q的j结点移为T的i结点 */ q[j]=Nil; /* 把q的j结点置空 */ } Status InsertChild(SqBiTree T,TElemType p,Status LR,SqBiTree c) { /* 初始条件: 二叉树T存在,p是T中某个结点的值,LR为0或1,非空二叉树c与T */ /* 不相交且右子树为空 */ /* 操作结果: 根据LR为0或1,插入c为T中p结点的左或右子树。p结点的原有左或 */ /* 右子树则成为c的右子树 */ int j,k,i=0; for(j=0;j<(int)pow(2,BiTreeDepth(T))-1;j++) /* 查找p的序号 */ if(T[j]==p) /* j为p的序号 */ break; k=2*j+1+LR; /* k为p的左或右孩子的序号 */ if(T[k]!=Nil) /* p原来的左或右孩子不空 */ Move(T,k,T,2*k+2); /* 把从T的k结点开始的子树移为从k结点的右子树开始的子树 */ Move(c,i,T,k); /* 把从c的i结点开始的子树移为从T的k结点开始的子树 */ return OK; } void Print(SqBiTree T) { /* 逐层、按本层序号输出二叉树 */ int j,k; position p; TElemType e; for(j=1;j<=BiTreeDepth(T);j++) { printf("第%d层: ",j); for(k=1;k<=pow(2,j-1);k++) { p.level=j; p.order=k; e=Value(T,p); if(e!=Nil) printf("%d:%d ",k,e); } printf("\n"); } } void main() { int j; TElemType e; SqBiTree T,s; InitBiTree(T); CreateBiTree(T); printf("建立右子树为空的树s:\n"); CreateBiTree(s); printf("树s插到树T中,请输入树T中树s的双亲结点 s为左(0)或右(1)子树: "); scanf("%d%d",&e,&j); InsertChild(T,e,j,s); Print(T); }
/
本文档为【树的插入】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。 本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。 网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
热门搜索

历史搜索

    清空历史搜索