- 1、本文档共25页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构实验指书(C)
《》实验指导书
(适用于计算机、)
信息工程系
目录
前言 1
实验一、单链表的基本操作 2
实验二 栈和队列 4
实验三 串 6
实验四 二叉树的遍历 8
实验五 树的应用 11
实验六 图 13
实验七、折半查找和二叉排序树 15
实验八、内部排序 17
前言
《数据结构》是的专业课主要介绍如何合理地组织数据、有效地存储和处理数据,正确地设计算法以及对算法分析和评价。本课程的学习使学生理解数据结构的逻辑结构和物理结构的基本概念及有关算法,培养基本的、良好的程序设计技能是一门理论和实践相结合的课程它在整个计算机专业教学体系中处于举足轻重的地位是计算机科学的算法理论基础和软件设计的技术基础,数据结构各章主要算法程序设计和程序调试的能力,加深对数据结构算法的理解。??
实验一? 链表的操作
一、实验目的
1、通过实验,掌握链表的输入与输出
2、通过实验,掌握链表的基本操作
二、实验内容
1、建立自己的有关链表的头文件
2、练习链表的输入与输出
3、练习链表的基本操作的实现
4、练习链表基本操作的应用
三、实验前的准备
1、复习相关课程内容,理解并掌握链表基本操作算法
2、准备相关的程序清单
3、
四、实验步骤与方法
(一)、理解并运行下面的程序
将用户输入的数据按头插入法建立一个带头结点的单链表。输入结点数据时以输入一串字符的方式实现,$字符为结束输入字符。
#include? “datastru.h”
#include? stdio.h
#include? malloc.h
?
int count_head(LINKLIST *head){
/*:输出单链表元素值并计数*/
? int I = 0;
? LINKLIST *p;
? p = head-next;
? printf(“输出单链表元素值 : “);
? while(p != NULL)
?? {printf(“? %c”,p-data);
I++;
p = p-next;}
? printf(“\n”);
? return I;
}
?
LINKLIST *creatlink_head_head(LINKLIST *head) {
/*用头插入法建立带头结点的单链表*/
? LINKLIST? *t;
??char ch;
? t = (LINKLIST *)malloc(sizeof(LINKLIST));
? head = t;
? t-next = NULL;
? printf(“单链表元素值为单个字符, 连续输入,$为结束字符? : “);
? while((ch = getchar())!= ‘$’)
?? {t = (LINKLIST *) malloc(sizeof(LINKLIST));
t-data = ch;
t-next = head-next;
head-next = t;}
? return(head);
}
?
main()
?{ LINKLIST *head = NULL;
?? int num;
?
?? printf(“\n??? 建立单链表\n\n”);
?? head = creatlink_head_head(head);
?? fflush(stdin);
?? num = count_head(head);
?? printf(“单链表元素个数 = %d\n”, num);
}
运行情况如下:
输入:
输出:
?
(二)、建立自己的头文件mylinklist.h,内容包括单链表数据结构的说明,链表的建立与输出、插入与删除操作等
?
?
要求:程序自己用附页附上
?
?
?
(三)、单链表基本操作的应用
1、
程序清单:
?
?
?
运行结果:
?
?
?
五、实验中出现的问题与解决方法
?
?实验二 栈与队列的基本操作
一、实验目的
1、通过实验,掌握输入与输出
2、通过实验,掌握栈与队列的基本操作
?
二、实验内容
3、建立相关的头文件
4、栈与队列的基本操作练习
三、实验前的准备
1、复习相关课程内容,掌握并理解栈与队列的基本操作
2、准备相关的程序清单
3、阅读实验指导书
四、实验步骤与方法
(一)、建立自己的有关栈与队列的头文件,内容包括栈与队列数据结构的说明,基本操作的实现等
?
(二)、完成一栈的建立与输出。写出程序及运行结果
?
(三)、完成一队列的建立与输出
?
?
五、实验中出现的问题与解决方法?
?实验三 串的操作
一、实验目的
1、通过实验,掌握顺序串的数据类型描述及基本操作的实现
二、实验内容
1、练习顺序串的应用
三、实验前的准备
1、复习课本的相关内容
2、阅读实验指导书
3、准备好相关的程序清单
四、实验步骤与方法
(一)、
文档评论(0)