《数据结构》实验指导书 - 图文(6)
实验七 查找的基本操作
一、
实验目的:
1. 掌握顺序查找的算法; 2. 掌握二分查找法;
3. 掌握二叉排序树的基本操作。
二、 实验内容:
1. 验证二分查找法;
2. 验证二叉排序树的基本操作。
三、 实验要求:
1. 认真阅读、掌握和上机运行本实验的程序; 2. 记录程序的运行结果,并结合程序进行分析; 3. 参照示例程序,完成相应功能的C程序设计编写。
四、 五、
实验学时:2学时 实验步骤:
1. 实验准备:
(1)完成教材第八章课后编程项目1-3题; (2)阅读源程序; (3)编写有关程序。
2. 拓展练习:阅读下列程序,写出各子函数功能和程序运行结果,再上机调试运行。
typedef struct {int elem[100]; int length; } SSTable;
int Searchs(SSTable s,int key) {int i;
s.elem[0]=key;
for(i=s.length;s.elem[i]!=key;i--); return(i); }
int Search_Bin( SSTable ST, int key) {int low, high,mid;
low=1; high=ST.length; while(low<=high) { mid=(low+high)/2;
if(ST.elem[mid]==key) return (mid);
else if( key {SSTable x; int I,y,k; clrscr(); printf(\请输入线性表的长度\ scanf(\ printf(\请输入线性表的各个元素\\n\ for(I=1;I<=x.length;I++) scanf(\ printf(\所建立的线性表为:\\n\ for(I=1;I<=x.length;I++) printf(\ printf(\请输入待查找的元素\ scanf(\ y=Searchs(x,k); if (y)printf(\有值为%d的元素,下标为%d\ else printf(\没有值为%d的元素\ printf(\以下验证折半查找,请建立一个有序表,输入线性表的长度\ scanf(\ for(I=1;I<=x.length;I++) x.elem[I]=I*4; printf(\所建立的线性表为?\\n\for(I=1;I<=x.length;I++) printf(\printf(\请输入待查找的元素\ scanf(\ y=Search_Bin(x,k); if (y)printf(\有值为%d的元素,下标为%d\ else printf(\没有值为%d的元素!\} 3. 拓展练习:阅读下列二叉排序树的程序,写出各函数的功能及程序运行结果,再上 机调试运行。 #include struct bnode *left,*right; } bitree; void output(t) bitree *t; { if (t!=NULL) { output(t->left); printf(\ output(t->right);} return; } bitree *insert(bitree *t,bitree *s) {bitree *p=t,*q; if (t==NULL) return s; while(p!=NULL) {q=p; if (s->data==p->data) return t; else {if (s->data>p->data) p=p->right; else p=p->left; } } if(s->data>q->data) q->right=s; else q->left=s; return t; } bitree *creat() { bitree *t,*s; int k,i,n,dat; t=NULL; /*scanf(\n=5; for(i=1;i<=n;i++) {scanf(\ s=(bitree *)malloc(sizeof(bitree)); s->left=NULL;s->right=NULL; s->data=dat; t=insert(t,s); } return t; } int delete(bitree *t,int x) {bitree *p=t,*q=NULL; while(p!=NULL) {if(p->data==x) break; else if(p->data>x) {q=p;p=p->left;} else {q=p;p=p->right;} } if(p==NULL) return 0; if((p->left==NULL)&&(p->right==NULL)) {if(p==t) t=NULL; else if(p==q->left) q->left=NULL; else q->right=NULL; free(p); } else if((p->left==NULL)||(p->right==NULL)) {if(p==t) {if(p->left==NULL) t=p->right; else t=p->left;} else {if((p==q->left)&&(p->left!=NULL)) q->left=p->left; else if(p==q->left&&p->right!=NULL) q->left=p->right; else if(p==q->right&&p->left!=NULL) q->right=p->left; else if(p==q->right&&p->right!=NULL) q->left=p->right; free(p); } }
…… 此处隐藏:357字,全部文档内容请下载后查看。喜欢就下载吧 ……
相关推荐:
- [高等教育]公司协助某村精准扶贫工作总结.doc
- [高等教育]高二生物知识点总结(全)
- [高等教育]苏教版数学三年级下册《解决问题的策略
- [高等教育]仪器分析课程学习心得
- [高等教育]2017年五邑大学数学与计算科学学院333
- [高等教育]人教版七年级下册语文第四单元测试题(
- [高等教育]2018年秋七年级英语上册Unit7Howmuchar
- [高等教育]2017年八年级下数学教学工作小结
- [高等教育]湖南省怀化市2019届高三统一模拟考试(
- [高等教育]四年级下册科学_基础训练及答案教材
- [高等教育]城郊煤矿西风井管路伸缩器更换施工安全
- [高等教育]昆八中20182019学年度上学期期末考试
- [高等教育]项目部各类人员任命书
- [高等教育]上市公司经营水务产业的模式
- [高等教育]人教版高二化学第一学期第三章水溶液中
- [高等教育]【中考物理第一轮复习资料】四.压强与
- [高等教育]金坑水电站报废改建工程机电设备更新改
- [高等教育]高中生物教学工作计划简易版
- [高等教育]2017年西华大学攀枝花学院(联合办学)44
- [高等教育]最新整理超短爆笑英文小笑话大全
- 优秀教师继续教育学习心得体会
- 阳历到阴历的转换
- 留守儿童教育案例分析
- 华师17春秋学期《玩教具制作与环境布置
- 测速传感器新型安装装置的现场应用
- 人教版小学数学三年级下册第四单元
- 创业个人意向书
- 山东省潍坊市2012年高考仿真试题(三)
- [恒心][好卷速递]四川省成都外国语学校
- 多少人错把好转反应当成了病情加重处理
- 中外广播电视史复习资料整理
- 江苏省扬州市江都区宜陵镇中学2014-201
- 工程造价专业毕业实习报告
- 广西师范学院心理与教育统计
- aympkrq基于 - asp的博客网站设计与开
- 建筑业外出经营相关流程操作(营改增后
- 人治 德治 法治
- [精华篇]常识判断专项训练题库
- 中国共产党为什么要实行民主集中
- 小学数学第三册第一单元试卷(A、B、C




