当前位置: 首页 > news >正文

软考程序员2016年上半年二叉排序树案例题解答

【说明】
二叉查找树又称为二叉排序树,它或者是一棵空树,或者是具有如下性质的二叉树。(1)若它的左子树非空,则左子树上所有结点的值均小于根结点的值。
(2)若它的右子树非空,则右子树上所有结点的值均大于根结点的值。
(3)左、右子树本身就是两棵二叉查找树。
二叉查找树是通过依次输入数据元素并把它们插入到二叉树的适当位置上构造起来的,具体的过程是:每读入一个元素,建立一个新结点,若二叉查找树非空,则将新结点的值与根结点的值相比较,如果小于根结点的值,则插入到左子树中,否则插入到右子树中;若二叉查找树为空,则新结点作为二叉查找树的根结点。
根据关键码序列{46,25,54,13,29,91}造一个二叉查找树的过程如图4-1所示。

设二叉查找树采用二叉链表存储,结点类型定义如下:

typedef int KeyType;
typedef struct BSTNode{
KeyType key;
struct BSTNode *left,*right;
}BSTNode,*BSTree;


图4-1(g)所示二叉查找树的二叉链表表示如图4-2所示。

函数int InsertBST(BSTree *rootptr,KeyTyp e kword)功能是将关键码kword插入到由roo tptr指示出根结点的二叉查找树中,若插入成功,函数返回1,否则返回0。

 【C代码】

int InsertBST(BSTree*rootptr, KeyType k word)//在二叉查找树中插入一个键值为kword的结点,若插入成功返回1,否则返回0;
//rootptr为二叉查找树根结点的指针{BSTree p,father;_(1)_;//将father初始化为空指针p=*rootptr;//*p指向二叉查找树的根节点while(p&&(2) ){//在二叉查找树中查找键值kword的结点father=p;if(kword<p->key)p=p->left;elsep=p-> right;}if(_(3)_) return 0;//二叉查找树中已包含键值kword,插入失败p=(BSTree)malloc(_(4));//创建新结点用来保存键值kword
If(!p)return 0;//创建新结点失败
p->key=kword;
p->left=NULL;
p-> right=NULL;
If(!father)
_(5)_=p; //二叉查找树为空树时新结点作为树根插入
else
if(kword< father->key)
_(6); //作为左孩子结点插入
else
_(Z)_;//作为右孩子结点插入
return 1;
}/*InsertBST*/

参考答案:

1)father=0/father=NULL

2) keyword!=p->key

3)p

4) sizeof(BSTNode)

5) *rootptr

6) father->left=p

7) father->right=p

所属知识点:

C程序设计>C程序设计

解析

本题考查C程序设计的基本结构和数据结构的实现。

根据二叉查找树的定义,其左子树中结点的关键码均小于树根结点的关键码,其右子树中结点的关键码均大于根结点的关键码,因此,将一个新关键码插入二叉查找树时,若等于树根或某结点的关键码,则不再插入,若小于树根,则将其插入左子树中,否则将其插入右子树中。

根据注释,空(1)处需将father设置为空指针,应填入"father=NULL"或其等价形式。空(2)所在语句用于查找新关键码的插入位置,p指向当前结点。查找结果为两种:若找到,则p指向的结点的关键码等于新关键码,若没有找到,则p得打空指针值。因此空(2)处应填入"p->key!=kword"或其等价形式,在得到结果前使得查找过程可以继续,并且用father记录新插入结点的父结点指针。

空(3)处应填入"p"或其等价形式,表明查找到了kword相同的结点,无须在插入该关键码。

空(4)处应填入"sizeof(BSTNODE)",在申请新结点空间时提供结点所需的字节数。空(5)处应填入"*rootptr",使得新结点作为树根结点时,树根结点的指针作为二叉链表的标识能得到更新。

根据注释,空(6)应填入"father->left=p"、空(7)应填入"father->right=p"。

http://www.dtcms.com/a/614861.html

相关文章:

  • LIN总线
  • 彩票走势图网站是用什么程序做的做原型的素材网站
  • 现在建网站还能赚钱吗在线教育网站建设策划
  • 梅州市住房和建设局网站网络广告文案案例
  • C++ 对象布局之padding(填充字节)
  • 做直播的视频在线观看网站成都网站制作报价
  • 现在都用什么软件做网站创建网站有免费的吗
  • MVC 布局:深入解析其原理与实践
  • iis添加网站网站设计就业前景如何
  • 学院网站建设策划书wordpress的功能简介
  • LeetCode 热题 100——滑动窗口——找到字符串中所有字母异位词
  • 土动静扭剪三轴仪技术指标
  • exe文件反编译成C语言 | 反编译技巧与应用分析
  • 指数型枚举
  • 竞价网站策划网站建设在作用是什么原因
  • 遵义住房城乡建设厅网站邯郸网站建设恋家
  • LeetCode 面试经典 150_二叉树_路径总和(75_112_C++_简单)(DFS)
  • 赋能职业教育:大众ID.4 CROZZ新能源汽车故障诊断仿真教学软件
  • 网站前端是什么意思品牌策划公司推荐
  • Linux字符设备驱动开发详细教程(简单字符设备驱动框架)
  • 电商网站建设运城商务网站建设难不难
  • 【Linux日新月异(三)】CentOS 7软件管理深度指南:从YUM到源码编译
  • 有了空间和域名 网站容易做吗长沙免费旅游景点大全
  • Linux网络NAT、代理服务和内网穿透
  • wordpress链接 颜色济南网站优化小黑
  • 微信授权登录第三方网站开发做h5网站的公司
  • 企业手机网站开通商城建站系统多少钱
  • 全栈项目实战经验,前后端分离开发流程
  • C# 中使用 Influxdb 1.x(四)——在程序内管理Influxdb服务的启停
  • 大模型的On-Policy Distillation(在线蒸馏策略)