ImageVerifierCode 换一换
格式:DOC , 页数:19 ,大小:134KB ,
资源ID:4356248      下载积分:8 金币
验证码下载
登录下载
邮箱/手机:
图形码:
验证码: 获取验证码
温馨提示:
支付成功后,系统会自动生成账号(用户名为邮箱或者手机号,密码是验证码),方便下次登录下载和查询订单;
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/4356248.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请。


权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4009-655-100;投诉/维权电话:18658249818。

注意事项

本文(数据结构二叉排序树课程设计报告.doc)为本站上传会员【丰****】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

数据结构二叉排序树课程设计报告.doc

1、课 程 设 计 报 告 ——数据结构 题目:二叉排序树     姓 名:            学   号:    专  业:          班  级:          指导老师: 年  月 日 目 录 一、课程设计简介ﻩ3 二、原理分析及流程 3 2、1、原理分析、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、3   2、2、流

2、程图、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、4 1、main()函数、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、4    2、创建、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、4   3、插入、、、、、、、、、、、、、、、、、、、、

3、5   4、查找、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、6 5、中序遍历输出ﻩ7 三、算法描述ﻩ8 3、1、存储结构 8 3、2、插入算法 8 3、3、查找算法ﻩ9 3、4、删除算法 10 四、小结与体会ﻩ12 五、程序执行过程ﻩ13   5、1、创建二叉排序树并中序输出、、、、、、、、、、、、、、、、、、、、、、、、、、、、

4、13 5、2、插入并中序输出、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、13    5、3、查找、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、14 六、程序清单 14 一、课程设计简介    1、1、题目:二叉排序树相关操作 1、创建二叉排序树;2、插入给定值; 3、查找给定值;    4、删除给定值得结点。   1、2、报告要求: 1、封面;

5、     2、题目与流程图或模块图; 3、程序清单与运行结果;  4、小结(收获与体会); 5、装订成册. 1、3、目得:   课程设计为学生提供了一个既动手又动脑,独立实践得机会,将课本上得理论知识与实际有机得结合起来,锻炼学生得分析解决实际问题得能力。提高学生适应实际,实践编程得能力。 二、原理分析及流程 2、1、原理分析: 根据题目要求,要实现这些功能,就必须创建一个菜单。这个菜单设置在main()函数里面,然后使用while()、、、switch()语句进行循环调用相关函数,以达到实现相关功能得目得。  2、2、流程图: 选择操作 m

6、ain()开始 选择1 创建 选择2 插入 选择3 查找 选择4 删除 选择5 退出   1、main()函数: Create(&t) 输入结点值,以-1结束 调用插入函数 ﻩ 2、创建:       3、插入: Insert(&t,x) 输入给定得结点值 *t==null x<(*t)->key insert(&((*t)->lchild)x); insert(&((*t)->rchild)x) *t=s 结束 N     Y ﻩN                Y

7、   4、查找: 返回search(p->rchild,x) 输入给定得结点值x,p=t P!=null xkey 返回search(p->lchild,x) 返回null search(t,x) 返回p->key x=p->key Y ﻩN ﻩYﻩN     5、中序遍历输出: display(t) t!=null display(t->lchild) 访问并输出根节点 display(t->rchild) 三、算法描述 3、1、存储结构 定义一个链表式得二叉排序树,用链表得方式构造结点,存储二叉排序树中得

8、结点、结点类型与指针类型如下:  #include 〈stdio、h>  #define null 0     typedef int keytype;   typedef struct node  {     keytype key;   struct node *lchild,*rchild;   }bstnode,*bstree; 3、2、插入算法   在二叉排序树中插入一个新节点,首先要查找该节点在二叉排序树中就是否已经存在。若二叉排序树中不存在关键字等于x得节点,则插入.   将一个关键字值

9、为x得节点s插入到二叉排序树中,可以用下面得方法:   (1)若二叉排序树为空,则关键字为x得节点s成为二叉排序树得根   (2)若二叉排序树非空,则将x与二叉排序树根进行比较,如果x得值等于根节点关键值,则停止插入;如果x得根节点值小于根节点关键值,则将x插入左子树;如果x得值大于根节点关键字得值,则将x插入右子树.在左右两个子树得插入方法与整个二叉排序树相同.    算法如下: void insert(bstree *t,keytype x) { bstree s; if(*t==null)   { ﻩs=(bstree)malloc(sizeof(bstnod

10、e)); ﻩs—〉key=x; ﻩs—>lchild=null; s-〉rchild=null; ﻩ*t=s;  }   else if(x<(*t)—>key) ﻩ insert(&((*t)—>lchild),x);   else if(x〉(*t)-〉key) ﻩ insert(&((*t)->rchild),x); } 3、3、查找算法   (1)若二叉排序树不为空,将根结点得关键字与待查关键字进行比较,若相等,则查找成功;若根节点关键字大于待查值,则进入左子树重复次步骤,否则,进入右子树进行此步骤;若在查找过程中遇到二叉排序树得叶子节点时,还没有找

11、到待查节点,则查找不成功. (2)否则,查找失败,返回null。   算法如下: bstree search(bstree t,keytype x) {  bstree p; p=t; if(p!=null) {  if (x==p->key) return p—>key; else if(x〈p->key) return search(p—〉lchild,x);  else return search(p->rchild,x); } else { printf(”%d can not be found\n",x);return nul

12、l; } } 3、4、删除算法  在二叉排序树中删除节点,首先要确定被删除得节点就是否在二叉排序树中。   若不在,则不做任何操作;否则,假设要删除得节点为p,节点p得父节点为r,并假设p就是r得左孩子。根据被删除节点p有无孩子,删除部分可做以下3中情况讨论:   (1)若p为叶子节点,则可令其父节点r得左孩子指针域为空,直接将其删除。   (2)若p节点只有右子树或左子树,则可以将p得左子树或右子树直接改为其双亲节点r得左子树。   (3)若p既有左子树又有右子树;将节点s为p得中序前驱。首先找到p得中序前驱节点s,然后用节点s得值代替节点p得值,再将节点s删除,

13、节点s得原左子树改为s得双亲节点q得右子树。 算法如下: bstree delete(bstree t,keytype x) { bstree p,q,r,s;   p=t; r=null; while(p) {   if(x==p-〉key)  break; r=p;     if(x〈p->key)  p=p-〉lchild;   else     p=p-〉rchild;   }  if(p==null)   {printf(”%d is not exist!\n",x);return t;}

14、  if((p—>lchild==null)||(p-〉rchild==null))    { ﻩ if(r==null) if(p—〉lchild==null) ﻩ    t=p-〉rchild; else t=p—〉lchild; ﻩ else if(p-〉lchild==null) ﻩ if(r—〉lchild==p)   r—〉lchild=p—>rchild; ﻩ else r->rchild=p—〉rchild; ﻩ   else if(r—>lchild==p) ﻩ     r->lch

15、ild=p-〉lchild;   else r-〉lchild=p—〉lchild; free(p);   } else    { ﻩ q=p; ﻩ s->lchild; while(s—〉rchild)      {q=s;s->rchild;} if(q==p)  q—>lchild=s—>lchild; ﻩ else      p->key=s->key;  free(s);    }    return t; }                     

16、       四、小结与体会   经过一个多星期来夜以继日得努力,终于把课程设计-—二叉排序树得相关算法全部完成!在编写程序过程中,让我对二叉排序树得创建、插入、查找、删除算法有了较系统得认识,也发现了一些以前纸上谈兵时得思想误区。比如实现插入功能时,从根节点开始比较;当实现删除功能时,如果待删除结点p左、右子树齐全,首先找到p得中序前驱节点s(p得中序前驱),然后用节点s得值代替节点p得值,再将节点s删除,节点s得原左子树改为s得双亲节点q得右子树.实现中序遍历功能时,采用递归思想、、、、、、 这就是第一次关于编写程序得课程设计.虽然上机安排只有两天时间,可却并不像平时上机实验

17、一样,离开了机房就不用再对着电脑屏幕编写代码,更多得工作实在离开机房后完成得。一遍一遍地按F9调试程序,error从几十个减少到几个,再到只剩几个warring,当按下Ctrl+F9,那精心设计得“菜单”出现在屏幕上时,那一刻得心情无以言表!涌上心头得除了自豪感、成就感之外,还有对编程工作之辛苦得慨叹!因为自己专业将来得方向与这有关,不免让我考虑起毕业后得发展方向。如果朝这方面发展得话,我就是否可以胜任这样得工作?如果不就是,又该选择什么? 五、 程序执行过程   5、1、创建二叉排序树并中序输出   5、2插入并中序输出     5、3、查找    5

18、4、删除并中序输出   六、程序清单 #include <stdio、h〉 #define null 0 typedef int keytype; typedef struct node { keytype key; struct node *lchild,*rchild; }bstnode,*bstree; void insert(bstree *t,keytype x); bstree search(bstree t,keytype x); void display(bstree t); void create(bstree *t) { keyt

19、ype x; *t=null; scanf(”%d",&x); while(x!=-1) { insert(t,x);  scanf("%d”,&x); } } void insert(bstree *t,keytype x) {   bstree s; if(*t==null) { ﻩs=(bstree)malloc(sizeof(bstnode)); ﻩs—>key=x; ﻩs->lchild=null; s-〉rchild=null; ﻩ*t=s;   }   else if(x〈(*t)->key) insert(

20、*t)—>lchild),x);   else if(x>(*t)—〉key) ﻩ insert(&((*t)->rchild),x); } bstree search(bstree t,keytype x) { bstree p; p=t;  if(p!=null) {  if (x==p->key) return p->key; else if(x<p—>key) return search(p—>lchild,x);   else return search(p->rchild,x); }  else { printf("%d can

21、not be found\n”,x); return null; } } bstree delete(bstree t,keytype x) { bstree p,q,r,s; p=t; r=null; while(p) {    if(x==p-〉key)  break;     r=p;   if(xlchild;     else         p=p->rchild;    }  if(p==null)   {printf("%d is not exist!\n”,x);

22、return t;} if((p—〉lchild==null)||(p-〉rchild==null))     { ﻩ if(r==null)  if(p—〉lchild==null) ﻩ  t=p-〉rchild; ﻩ else ﻩ     t=p-〉lchild; else if(p—>lchild==null) ﻩ if(r->lchild==p) r->lchild=p-〉rchild; ﻩ else   r—〉rchild=p->rchild;     else if(r->lchild=

23、p) ﻩﻩ  r-〉lchild=p->lchild; else ﻩﻩ r-〉lchild=p->lchild; ﻩ free(p);   } else    { q=p; s->lchild; ﻩ while(s-〉rchild)   {q=s;s->rchild;} ﻩ if(q==p)  q->lchild=s—〉lchild; else ﻩ   p-〉key=s-〉key; free(s); }   return t; } void display(b

24、stree t) {  if(t!=null)   { display(t->lchild); ﻩprintf("%5d",t-〉key); ﻩdisplay(t—>rchild); } } void main(void) {  bstree t,b; int i=1,j; keytype x; while(i) { printf(”\n* * * * * * * * * * * * * * * *\n"); ﻩprintf("\n* MENU OF BSTREE     *\n”); ﻩprintf(”\n*  1、

25、create 2、insert   *\n"); ﻩprintf("\n*   3、search   4、delete   *\n”); ﻩprintf("\n*     5、exit      *\n"); ﻩprintf("\n* * * * * * * * * * * * * * * *\n”);   printf(” what do you want to do? :");scanf("%d”,&j); switch(j) {     case  1: printf("input bstree’s v

26、alues,end with -1:\n");create(&t); ﻩﻩﻩprintf("bstree's root is %d\n”,t->key);display(t);break;    case   2: printf("input the insert value:”);scanf(”%d",&x); ﻩﻩﻩﻩinsert(&t,x);display(t);break;   case 3: printf("input the search value:");scanf(”%d”,&x); ﻩﻩ ﻩprintf("result is: %d",search(t,x));break;    case 4: printf("input the delete value:");scanf(”%d",&x); ﻩﻩ delete(t,x);display(t);break;     case 5: i=0;break;      } } clrscr(); }

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服