数据结构实验报告四林昌雄
《数据结构》(C语言)实验报告

《数据结构》实验报告姓名:**学号:*********成绩:_____目录实验一,线性表的应用 (3)实验二,栈和队列的应用 (8)实验三,数组的应用 (13)实验四,树和二叉树的应用 (19)实验五,图的应用 (24)实验六,查找表的应用 (32)实验七,排序算法的应用 (44)实验一线性表的应用【实验目的】1.熟练掌握线性表的基本操作在顺序存储和链式存储上的实现;2.以线性表的各种操作(建立、插入、删除、遍历等)的实现为重点;3.掌握线性表的动态分配顺序存储结构的定义和基本实现;4.通过对本章实验帮助学生加深对C语言的使用(特别是函数参数调用、指针类型的应用和链表的建立等各种基本操作)。
【实验内容】约瑟夫问题的实现:n只猴子要选猴王,所有猴子按1,2,…,n编号围坐一圈,从第1只开始按1,2,…,m报数,凡报到m号的猴子退出圈外,如此循环报数,直到圈内省剩下一只猴子时,这个猴子就是猴王。
编写一个程序实现上述过程,n和m由键盘输入。
【实验要求】1.要求用顺序表和链表分别实现约瑟夫问题;2.独立完成,严禁抄袭;3.上交的实验报告由如下部分组成:①实验名称②实验目的③实验内容(问题描述,算法描述,程序清单,测试结果,算法分析)。
实验结果:一,源程序:#include<stdio.h> #include<stdlib.h>#define Maxsize 80struct SeqList{int data[Maxsize];int len;};typedef struct SeqList SeqList;void InitList(SeqList *L){L=(SeqList *)malloc(sizeof(SeqList)); L->len=0;}void MadeList(SeqList *L){int i;int people;printf("请输入参选的总数:\n"); scanf("%d",&people);for (i=0;i<people;i++){L->data[i]=i+1;printf(" %d ",L->data[i]); }printf("\n");L->len=people;}void WentList(SeqList *L){int m,i,j;int k=0;printf("请输入出列数:\n"); scanf("%d",&m);for (i=L->len;i>0;i--){k=(k+m-1)%i;printf(" %d ",L->data[k]); for (j=k;j<i-1;j++){L->data[j]=L->data[j+1]; }L->len=L->len-1;}printf("\n");}void main(){SeqList *L;InitList(L);MadeList(L);WentList(L);}二,运行结果及截屏视图:实验二栈和列队的应用【实验目的】1.熟练掌握栈和列队的结构,以及这两种数据结构的特点;2.能够在两种存储结构上实现栈的基本运算,特别注意栈满和栈空时的判断条件和描述方法;3.熟练掌握链队列和循环列表的基本运算,特别注意队列满和队列空时的判断条件和描述方法。
数据结构课程设计实验报告完整版

数据结构课程设计实验报告完整版【正文】一、实验目的本实验主要目的是通过实践,掌握数据结构的基本概念、常见数据结构的实现方式以及在实际应用中的应用场景和效果。
二、实验背景数据结构是计算机科学与技术领域中的一个重要概念,是研究数据的组织方式、存储方式、访问方式以及操作等方面的方法论。
在计算机科学领域,数据结构是实现算法和解决问题的基础,因此对数据结构的理解和应用具有重要意义。
三、实验内容本次数据结构课程设计实验主要分为以下几个部分:1. 实验环境的准备:包括选择合适的开发平台、安装必要的软件和工具。
2. 实验数据的收集和处理:通过合适的方式收集实验所需的数据,并对数据进行处理和整理。
3. 数据结构的选择和实现:根据实验需求,选择合适的数据结构,并进行相应的数据结构实现。
4. 数据结构的测试和优化:对所实现的数据结构进行测试,包括性能测试和功能测试,并根据测试结果对数据结构进行优化和改进。
5. 实验报告的撰写:根据实验过程和结果,撰写完整的实验报告,包括实验目的、实验背景、实验内容、实验结果和结论等。
四、实验过程1. 实验环境的准备本实验选择了Visual Studio作为开发平台,安装了相应版本的Visual Studio,并根据官方指引进行了相应的配置和设置。
2. 实验数据的收集和处理本实验选取了一份包含学生信息的数据集,包括学生姓名、学号、性别、年龄等信息。
通过编写Python脚本,成功提取了所需信息,并对数据进行了清洗和整理。
3. 数据结构的选择和实现根据实验需求,我们选择了链表作为数据结构的实现方式。
链表是一种常见的动态数据结构,能够高效地插入和删除元素,适用于频繁插入和删除的场景。
在实现链表时,我们定义了一个节点结构,包含数据域和指针域。
通过指针的方式将节点连接起来,形成一个链式结构。
同时,我们还实现了相关的操作函数,包括插入、删除、查找等操作。
4. 数据结构的测试和优化在完成链表的实现后,我们对其进行了性能测试和功能测试。
数据结构实验报告

数据结构实验报告数据结构实验报告1-引言本实验旨在深入理解数据结构的基本知识,并通过实践掌握相关算法和数据结构的应用。
本报告详细描述了实验的背景、目的、实验环境、实验内容和实验结果分析等内容。
2-实验背景介绍数据结构的概念和作用,解释为什么数据结构在计算机科学中至关重要。
同时,介绍本次实验所涉及的具体数据结构和算法,如数组、链表、栈、队列、二叉树等。
3-实验目的明确本次实验的目标,如掌握数据结构的基本操作,理解不同数据结构的适用场景,评估不同算法的时间和空间复杂度等。
4-实验环境描述实验所使用的软硬件环境,包括计算机配置、操作系统、编程语言和相关的开发工具等。
5-实验内容详细描述实验的具体步骤和要求,包括以下几个部分:5-1 数据结构的创建和初始化:例如,创建一个数组或链表,并初始化数据。
5-2 数据结构的插入和删除操作:例如,在数组中插入一个元素或删除一个元素。
5-3 数据结构的遍历和搜索:例如,遍历树的节点或搜索链表中指定的元素。
5-4 数据结构的排序和查找:例如,对数组进行排序或在有序链表中查找指定元素。
5-5 实验的额外要求:例如,优化算法的实现、分析不同数据结构的性能等。
6-实验结果分析对实验的结果进行详细的分析和解释,包括各个数据结构和算法的性能比较、时间复杂度和空间复杂度的评估等。
7-结论总结本次实验的主要内容和收获,归纳实验结果,并对实验过程中遇到的问题和不足进行反思和改进。
附件:随报告一同提交的附件包括:源代码、实验数据集等相关文件。
法律名词及注释:1-版权:指作品的创作权、发表权和署名权等综合权利。
2-侵权:指未经权利人允许,在未向权利人支付报酬的情况下,使用受版权保护的作品的行为。
3-知识产权:包括著作权、商标权、专利权等,是指人们在创造性劳动中创造出的精神财富所享有的权利。
数据结构实验报告四林昌雄

一、算法基本思想:(1) 顺序查找:建立顺序表,从表内第一个数值开始与给定值比较,若相等,则查找成功;否则,用下一个数值继续进行比较,直到数值等于给定值或者线性表已比较完(查找不成功)为止。
(2) 首先提示用户建立有序数组的长度,然后输入有序的数据,接着提示用户输入要查找的元素,通过调用binarySearch()来判断用户要查找的元素是否在此数组中,如果返回值是-1则说明用户查找的数据不在此数组中,否则输出在此数组中。
但是,折半查找的先决条件是查找表中的数据元素必须有序。
查找过程中采用跃式方查找,即先以有序数列的中点位置为比较对象,如果要找的元素值小于该中点元素,则待查序列缩小为左半部分,否则为右半部分。
通过一次比较,将查找区间缩小一半。
折半查找是一种高效的查找方法。
它可以明显减少比较次数,提高查找效率。
二、结构定义:线性表的结构定义:有序表的结构定义:typedef struct typedef struct{ {Elemtype *elem; KeyType Key;int length; }int listsize; }Elemtype;}SqList;三、算法描述:int Search_Bin2(SqList &L,KeyType key) {//在有序表ST中折半查找其关键字等于//key的数据元素。
若找到,则函数值为该元//素在表中的位置,否则为0int low,high,mid;low=1;high=L.length;//置区间初值while(low<=high){mid=(low+high)/2;if(EQ(key,L.elem[mid].key))//找到待查元素{printf("待查元素的位置:%d\n",mid+1);return OK; }else if(LT(key,L.elem[mid].key)) high=mid-1;//继续在前半区间进行查找else low=mid+1;//继续在后半区间进行查找}printf("待查元素不存在");return OK;}Status Search_Bin1(SqList &L,int key){//在顺序表Sq中顺序查找其关键字等于//key的数据元素。
数据结构实验实训报告范文

一、实验目的1. 理解并掌握数据结构的基本概念和常用算法。
2. 学会使用C语言实现线性表、栈、队列、树和图等基本数据结构。
3. 培养动手实践能力,提高编程水平。
二、实验内容1. 线性表(1)顺序表(2)链表2. 栈(1)顺序栈(2)链栈3. 队列(1)顺序队列(2)链队列4. 树(1)二叉树(2)二叉搜索树5. 图(1)邻接矩阵表示法(2)邻接表表示法三、实验环境1. 操作系统:Windows 102. 编程语言:C语言3. 编译器:Visual Studio 20194. 实验软件:C语言开发环境四、实验步骤1. 线性表(1)顺序表1)定义顺序表结构体2)实现顺序表的初始化、插入、删除、查找等基本操作3)编写测试程序,验证顺序表的基本操作(2)链表1)定义链表结构体2)实现链表的创建、插入、删除、查找等基本操作3)编写测试程序,验证链表的基本操作2. 栈(1)顺序栈1)定义顺序栈结构体2)实现顺序栈的初始化、入栈、出栈、判空等基本操作3)编写测试程序,验证顺序栈的基本操作(2)链栈1)定义链栈结构体2)实现链栈的初始化、入栈、出栈、判空等基本操作3)编写测试程序,验证链栈的基本操作3. 队列(1)顺序队列1)定义顺序队列结构体2)实现顺序队列的初始化、入队、出队、判空等基本操作3)编写测试程序,验证顺序队列的基本操作(2)链队列1)定义链队列结构体2)实现链队列的初始化、入队、出队、判空等基本操作3)编写测试程序,验证链队列的基本操作4. 树(1)二叉树1)定义二叉树结构体2)实现二叉树的创建、遍历、查找等基本操作3)编写测试程序,验证二叉树的基本操作(2)二叉搜索树1)定义二叉搜索树结构体2)实现二叉搜索树的创建、遍历、查找等基本操作3)编写测试程序,验证二叉搜索树的基本操作5. 图(1)邻接矩阵表示法1)定义邻接矩阵结构体2)实现图的创建、添加边、删除边、遍历等基本操作3)编写测试程序,验证邻接矩阵表示法的基本操作(2)邻接表表示法1)定义邻接表结构体2)实现图的创建、添加边、删除边、遍历等基本操作3)编写测试程序,验证邻接表表示法的基本操作五、实验结果与分析1. 线性表(1)顺序表实验结果表明,顺序表的基本操作实现正确,测试程序运行稳定。
数据结构实验报告简版

数据结构实验报告数据结构实验报告实验目的本实验旨在通过实践,加深对数据结构的理解,掌握数据结构的基本操作,并学会运用数据结构解决实际问题。
实验背景数据结构是计算机科学中非常重要的基础知识,它是研究各种数据结构及其相应算法的学科。
数据结构可以提供对数据的组织、存储和管理方式,从而有效地支持计算机程序的设计和运行。
实验内容本实验主要包括以下几个方面的内容:1. 线性表的操作- 插入操作:向线性表的指定位置插入元素。
- 删除操作:从线性表中删除指定位置的元素。
- 查找操作:在线性表中查找指定元素。
- 遍历操作:依次访问线性表中的所有元素。
2. 栈的应用- 中缀表达式转后缀表达式:将带有括号的中缀表达式转换为无括号的后缀表达式。
- 后缀表达式求值:根据后缀表达式计算其值。
3. 队列的应用- 模拟打印任务:根据打印任务的到达时间和执行时间,模拟打印机的工作过程。
4. 递归的应用- 计算斐波那契数列:通过递归函数计算斐波那契数列的第n 项值。
实验步骤根据实验内容,进行以下步骤:1. 线性表的操作1. 初始化线性表。
2. 实现插入操作,并在指定位置插入元素。
3. 实现删除操作,并从指定位置删除元素。
4. 实现查找操作,并根据指定元素在线性表中查找。
5. 实现遍历操作,并依次访问线性表中的所有元素。
2. 栈的应用1. 实现中缀表达式转后缀表达式的函数,并进行测试。
2. 实现后缀表达式求值的函数,并进行测试。
3. 队列的应用1. 实现模拟打印任务的函数,并根据指定的打印任务进行测试。
4. 递归的应用1. 实现计算斐波那契数列的递归函数,并计算第n项的值。
实验结果经过上述步骤的实现和测试,得到以下实验结果:- 线性表的操作:插入、删除、查找和遍历操作均得到正确的结果。
- 栈的应用:中缀表达式转后缀表达式和后缀表达式求值的函数均能正确运行。
- 队列的应用:模拟打印任务的函数能够按照指定的顺序执行打印任务。
- 递归的应用:计算斐波那契数列的递归函数能够正确计算任意一项的值。
数据结构课程实验报告

数据结构课程实验报告一、实验目的数据结构是计算机科学中一门重要的基础课程,通过本次实验,旨在加深对数据结构基本概念和算法的理解,提高编程能力和解决实际问题的能力。
具体目标包括:1、掌握常见数据结构(如数组、链表、栈、队列、树、图等)的基本操作和实现方法。
2、学会运用数据结构解决实际问题,培养算法设计和分析的能力。
3、提高程序设计的规范性和可读性,培养良好的编程习惯。
二、实验环境本次实验使用的编程语言为C++,开发环境为Visual Studio 2019。
三、实验内容本次实验共包括以下几个部分:(一)线性表的实现与操作1、顺序表的实现定义一个顺序表结构体,包含数据元素数组和表的长度。
实现顺序表的初始化、插入、删除、查找等基本操作。
2、链表的实现定义链表节点结构体,包含数据域和指针域。
实现链表的创建、插入、删除、遍历等操作。
(二)栈和队列的实现与应用1、栈的实现采用顺序存储或链式存储实现栈。
实现栈的入栈、出栈、栈顶元素获取等操作,并应用于表达式求值。
2、队列的实现用循环队列或链式队列实现队列。
实现队列的入队、出队、队头元素获取等操作,应用于模拟排队系统。
(三)树的基本操作与遍历1、二叉树的实现定义二叉树节点结构体,包含数据域、左子树指针和右子树指针。
实现二叉树的创建、插入、删除节点等操作。
2、二叉树的遍历分别实现前序遍历、中序遍历和后序遍历,并输出遍历结果。
(四)图的表示与遍历1、邻接矩阵和邻接表表示图定义图的结构体,使用邻接矩阵和邻接表两种方式存储图的信息。
实现图的创建、添加边等操作。
2、图的遍历分别用深度优先搜索(DFS)和广度优先搜索(BFS)遍历图,并输出遍历序列。
四、实验步骤(一)线性表的实现与操作1、顺序表的实现首先,定义了一个结构体`SeqList` 来表示顺序表,其中包含一个整数数组`data` 用于存储数据元素,以及一个整数`length` 表示表的当前长度。
在初始化函数`InitSeqList` 中,将表的长度初始化为 0,并分配一定的存储空间给数组。
数据结构的实验报告

一、实验目的本次实验旨在让学生掌握数据结构的基本概念、逻辑结构、存储结构以及各种基本操作,并通过实际编程操作,加深对数据结构理论知识的理解,提高编程能力和算法设计能力。
二、实验内容1. 线性表(1)顺序表1)初始化顺序表2)向顺序表插入元素3)从顺序表删除元素4)查找顺序表中的元素5)顺序表的逆序操作(2)链表1)创建链表2)在链表中插入元素3)在链表中删除元素4)查找链表中的元素5)链表的逆序操作2. 栈与队列(1)栈1)栈的初始化2)入栈操作3)出栈操作4)获取栈顶元素5)判断栈是否为空(2)队列1)队列的初始化2)入队操作3)出队操作4)获取队首元素5)判断队列是否为空3. 树与图(1)二叉树1)创建二叉树2)遍历二叉树(前序、中序、后序)3)求二叉树的深度4)求二叉树的宽度5)二叉树的镜像(2)图1)创建图2)图的深度优先遍历3)图的广度优先遍历4)最小生成树5)最短路径三、实验过程1. 线性表(1)顺序表1)初始化顺序表:创建一个长度为10的顺序表,初始化为空。
2)向顺序表插入元素:在顺序表的第i个位置插入元素x。
3)从顺序表删除元素:从顺序表中删除第i个位置的元素。
4)查找顺序表中的元素:在顺序表中查找元素x。
5)顺序表的逆序操作:将顺序表中的元素逆序排列。
(2)链表1)创建链表:创建一个带头结点的循环链表。
2)在链表中插入元素:在链表的第i个位置插入元素x。
3)在链表中删除元素:从链表中删除第i个位置的元素。
4)查找链表中的元素:在链表中查找元素x。
5)链表的逆序操作:将链表中的元素逆序排列。
2. 栈与队列(1)栈1)栈的初始化:创建一个栈,初始化为空。
2)入栈操作:将元素x压入栈中。
3)出栈操作:从栈中弹出元素。
4)获取栈顶元素:获取栈顶元素。
5)判断栈是否为空:判断栈是否为空。
(2)队列1)队列的初始化:创建一个队列,初始化为空。
2)入队操作:将元素x入队。
3)出队操作:从队列中出队元素。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
一、算法基本思想:(1) 顺序查找:建立顺序表,从表内第一个数值开始与给定值比较,若相等,则查找成功;否则,用下一个数值继续进行比较,直到数值等于给定值或者线性表已比较完(查找不成功)为止。
(2) 首先提示用户建立有序数组的长度,然后输入有序的数据,接着提示用户输入要查找的元素,通过调用binarySearch()来判断用户要查找的元素是否在此数组中,如果返回值是-1则说明用户查找的数据不在此数组中,否则输出在此数组中。
但是,折半查找的先决条件是查找表中的数据元素必须有序。
查找过程中采用跃式方查找,即先以有序数列的中点位置为比较对象,如果要找的元素值小于该中点元素,则待查序列缩小为左半部分,否则为右半部分。
通过一次比较,将查找区间缩小一半。
折半查找是一种高效的查找方法。
它可以明显减少比较次数,提高查找效率。
二、结构定义:线性表的结构定义:有序表的结构定义:typedef struct typedef struct{ {Elemtype *elem; KeyType Key;int length; }int listsize; }Elemtype;}SqList;三、算法描述:int Search_Bin2(SqList &L,KeyType key) {//在有序表ST中折半查找其关键字等于//key的数据元素。
若找到,则函数值为该元//素在表中的位置,否则为0int low,high,mid;low=1;high=L.length;//置区间初值while(low<=high){mid=(low+high)/2;if(EQ(key,L.elem[mid].key))//找到待查元素{printf("待查元素的位置:%d\n",mid+1);return OK; }else if(LT(key,L.elem[mid].key)) high=mid-1;//继续在前半区间进行查找else low=mid+1;//继续在后半区间进行查找}printf("待查元素不存在");return OK;}Status Search_Bin1(SqList &L,int key){//在顺序表Sq中顺序查找其关键字等于//key的数据元素。
若找到,则函数值为该元//素在表中的位置,否则为0int i,high;i=0;high=L.length;//置区间初值while (i<=high){if(EQ(key,L.elem[i].key))//找到待查元素{printf("待查元素的位置:%d\n",i+1);return OK;}else i++;//继续往下一位置进行查找}printf("待查元素不存在");return OK;}int main(){int key1,choose;int n,key2;int i;SqList L;//置区间初值printf("1.顺序表查找");printf("2.有序表查找");do{printf("\n请输入选择:");scanf("%d",&choose);switch(choose)//对顺序表和有序表进行选择{//根据选择结果进行顺序表程序运行或者有序表程序运行case 2:printf("有序表: ");InitList_Sq(L);Create_Sq(L);printf("输入待查元素: ");scanf("%d",&key1);Search_Bin2(L,key1);//调用函数printf("\n");break;case 1:int i,n;SqList L1;InitList_Sq(L1);printf("顺序表: ");Create_Sq(L1);printf("输入待查元素: ");scanf("%d",&n);Search_Bin1(L1,n);//调用函数printf("\n");break;default:printf("输入错误\n");}}while(choose);system("PAUSE");return EXIT_SUCCESS;}、四、程序清单:#include<stdio.h>#include<stdlib.h>#define LIST_INIT_SIZE 100#define LISTINCREMENT 10#define OK 1#define ERROR 0#define TRUE 1#define FALSE 0#define OVERFLOW -2#define INFEASIBLE -1#define EQ(a,b) ((a)==(b))#define LT(a,b) ((a)<(b))#define NQ(a,b) ((a)!=(b))typedef int KeyType;typedef int Status;typedef struct{KeyType key;}Elemtype;typedef struct{Elemtype *elem;int length;int listsize;}SqList;Status InitList_Sq(SqList &L){L.elem=(Elemtype*)malloc(LIST_INIT_SIZE *sizeof(Elemtype));if(!L.elem)exit(OVERFLOW);L.length=0;L.listsize=LIST_INIT_SIZE;return OK;}Status Create_Sq(SqList &L){int i,n;printf("输入线性表元素个数:");scanf("%d",&n);for(i=0;i<n;i++){scanf("%d",&L.elem[i]);L.length=i+1;}return OK;}int Search_Bin2(SqList &L,KeyType key) {int low,high,mid;low=1;high=L.length;while(low<=high){mid=(low+high)/2;if(EQ(key,L.elem[mid].key)){printf("待查元素的位置:%d\n",mid+1);return OK;}else if(LT(key,L.elem[mid].key)) high=mid-1;else low=mid+1;}printf("待查元素不存在");return OK;}Status Search_Bin1(SqList &L,int key){int i,high;i=0;high=L.length;while (i<=high){if(EQ(key,L.elem[i].key)){printf("待查元素的位置:%d\n",i+1);return OK;}else i++;}printf("待查元素不存在"); return OK;}int main(){int key1,choose;int n,key2;int i;SqList L;printf("1.顺序表查找");printf("2.有序表查找");do{printf("\n请输入选择:"); scanf("%d",&choose);switch(choose){case 2:printf("有序表: ");InitList_Sq(L);Create_Sq(L);printf("输入待查元素: ");scanf("%d",&key1);Search_Bin2(L,key1);printf("\n");break;case 1:int i,n;SqList L1;InitList_Sq(L1);printf("顺序表: ");Create_Sq(L1);printf("输入待查元素: ");scanf("%d",&n);Search_Bin1(L1,n);printf("\n");break;default:printf("输入错误\n"); }}while(choose);system("PAUSE");return EXIT_SUCCESS;}五、运行结果:六、分析与总结顺序查找与折半查找其本质是一样的,只是表现形式的差异和实现的速度差异。
顺序查找是比较简单的,只要逻辑比较清楚,按部就班就很容易把实现这个功能的程序写出来。
折半查找算是比较优化的一种代码,可以大大减少查找时间,我采用的是高中所学的算法,首先查找的关键字与最中间的数比较,大了则再比较右边,小了则比较左边。
算法也比较容易理解,我认为在静态查找中可以作为首选。