




全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
班级:计算机11-2 学号:40 姓名:朱报龙 成绩:_实验十 查找技术验证实验一、折半查找验证1. 实验目的 掌握折半查找算法的基本思想; 掌握折半查找算法的实现方法; 掌握折半查找算法的时间性能。2. 实验内容对给定的有序数组(假设长度为n),查找数组中与给定值k相等的元素.一、 设计与编码#include using namespace std;#define N 15 /定义常量N 为数组长度void find(int arr,int key,int i) /折半查找函数int low=0,high=N-1,mid,j=0; /j计数查找次数while(low=high)mid=(low+high)/2; /取中间位+j;printf(n 第%2d次查找 low=%2d high=%2d mid=%2d ,j,low,high,mid); /显示每次查找低中高位,查找次数if(arrmid=key) /查到数据,跳出循环break;if(arrmidkey) /查找的KEY大于中位值,查后半部low=mid+1;elsehigh=mid-1; /查找的KEY小于中位值,查前半部if(low=high) /查到数据 printf(nn经过总共%2d次查找,找到该数字,该数字位于数组第%d 位,nn,j,mid+1);/显示查到的数据的值,下标值,总查找次数elseprintf(nn没有找到!); /显示没有找到void main()int arrN,key,i;printf(n折半查找验证程序,设定被查数据有位,设定为:n);for(i=0;i0) find(arr,key,N); /调用折半查找函数printf(n请输入要查询的数字(,输入小于等于零的数字退出验证程序):);scanf(%d,&key); /输入KEY a) 程序运行的结果如何?二、二叉排序树的建立1. 实验目的 掌握二叉排序树定义和特性; 掌握二叉排序树的建立方法; 实现基于二叉排序树的查找技术; 掌握二叉排序树的查找性能。2. 实验内容 对给定的一组无序序列,建立一棵二叉排序树; 对建立的二叉排序树实现查找操作。二、 设计与编码#includeusing namespace std;class BTpublic :BT(void)/构造函数void InitBiTree(BiTree *t);coutlchild);coutkeyrchild); /查找数据BiTree SearchBST(BiTree t, int k) BiTree p;p=t;while(p!=NULL)&(p-key!=k)if(kkey) p=p-lchild;else p=p-rchild;return(p);/插入数据void InsertBST(BiTree *t,int k)BiTnode *f,*p=*t;while(p)if(p-key=k) return;f=p;p=(kkey)?p-lchild:p-rchild; p=(BiTree)malloc(sizeof(BiTnode);p-key=k;p-lchild=p-rchild=NULL;if(*t=NULL) *t=p;else if (kkey)f-lchild=p;else f-rchild=p;/在二叉排序树*t中删除关键字为k的结点BT()cout调用析构函数释放!endl;/ 析构private:;/class BTint main()BT bt;/class BT创建对象btBT:BiTree t=NULL,p;int key,q=1;bt.InitBiTree(&t);cout请输入关键字的值,以0结束:key; while(key)bt.InsertBST(&t,key); cinkey; cout中序遍历建立的二叉排序树的序列为:; bt.InorderBiTree(t); coutendl; cout请输入要插入的结点的关键字的值:key; bt.InsertBST(&t,key); cout插入后的二叉排序树的中序序列为:endl; bt.InorderBiTree(t); coutendl; cout请输入要查找的结点的关键字的值:key; p=bt.SearchBST(t,key)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年度样板房样板间租赁与展示协议
- 2025年金融机构安全防护服务合同范本
- 2025年度物联网创业借款合同范本模板
- 2025版体育设施委托代建管理协议
- 贵州省大方县2025年上半年事业单位公开遴选试题含答案分析
- 2025版室外地面铺砖施工进度跟踪合同
- 2025年度房产买卖及社区配套服务协议
- 2025年度建筑测绘简单合同范本
- 2025版税务局税收筹划与税务筹划支持合同
- 2025贷款反担保协议范本:跨境电商贷款反担保示范
- 【初中化学】二氧化碳的实验室制取课件-2024-2025学年九年级化学人教版上册
- 商场租户撤场协议书范本
- 九年级上册英语书译林版单词表
- 车库业主与租赁者安装充电桩协议书
- 园林工程竣工验收与养护期
- 儿童感觉统合能力发展评定量表
- 《养老护理员》-课件:协助老年人如厕
- 丙酸丙酯的分离工艺
- 二维层状材料的堆叠效应
- 审计资料交接清单
- 从业人员晨检记录表
评论
0/150
提交评论