数据结构实验报告模板

合集下载

数据结构课程设计实验报告完整版

数据结构课程设计实验报告完整版

数据结构课程设计实验报告完整版【正文】一、实验目的本实验主要目的是通过实践,掌握数据结构的基本概念、常见数据结构的实现方式以及在实际应用中的应用场景和效果。

二、实验背景数据结构是计算机科学与技术领域中的一个重要概念,是研究数据的组织方式、存储方式、访问方式以及操作等方面的方法论。

在计算机科学领域,数据结构是实现算法和解决问题的基础,因此对数据结构的理解和应用具有重要意义。

三、实验内容本次数据结构课程设计实验主要分为以下几个部分:1. 实验环境的准备:包括选择合适的开发平台、安装必要的软件和工具。

2. 实验数据的收集和处理:通过合适的方式收集实验所需的数据,并对数据进行处理和整理。

3. 数据结构的选择和实现:根据实验需求,选择合适的数据结构,并进行相应的数据结构实现。

4. 数据结构的测试和优化:对所实现的数据结构进行测试,包括性能测试和功能测试,并根据测试结果对数据结构进行优化和改进。

5. 实验报告的撰写:根据实验过程和结果,撰写完整的实验报告,包括实验目的、实验背景、实验内容、实验结果和结论等。

四、实验过程1. 实验环境的准备本实验选择了Visual Studio作为开发平台,安装了相应版本的Visual Studio,并根据官方指引进行了相应的配置和设置。

2. 实验数据的收集和处理本实验选取了一份包含学生信息的数据集,包括学生姓名、学号、性别、年龄等信息。

通过编写Python脚本,成功提取了所需信息,并对数据进行了清洗和整理。

3. 数据结构的选择和实现根据实验需求,我们选择了链表作为数据结构的实现方式。

链表是一种常见的动态数据结构,能够高效地插入和删除元素,适用于频繁插入和删除的场景。

在实现链表时,我们定义了一个节点结构,包含数据域和指针域。

通过指针的方式将节点连接起来,形成一个链式结构。

同时,我们还实现了相关的操作函数,包括插入、删除、查找等操作。

4. 数据结构的测试和优化在完成链表的实现后,我们对其进行了性能测试和功能测试。

《数据结构》实验报告模板(附实例)--实验一线性表的基本操作实现

《数据结构》实验报告模板(附实例)--实验一线性表的基本操作实现

《数据结构》实验报告模板(附实例)---实验一线性表的基本操作实现实验一线性表的基本操作实现及其应用一、实验目的1、熟练掌握线性表的基本操作在两种存储结构上的实现,其中以熟悉各种链表的操作为重点。

2、巩固高级语言程序设计方法与技术,会用线性链表解决简单的实际问题。

二、实验内容√ 1、单链表的表示与操作实现 ( * )2、约瑟夫环问题3、Dr.Kong的艺术品三、实验要求1、按照数据结构实验任务书,提前做好实验预习与准备工作。

2、加“*”题目必做,其他题目任选;多选者并且保质保量完成适当加分。

3、严格按照数据结构实验报告模板和规范,及时完成实验报告。

四、实验步骤(说明:依据实验内容分别说明实验程序中用到的数据类型的定义、主程序的流程以及每个操作(成员函数)的伪码算法、函数实现、程序编码、调试与分析、总结、附流程图与主要代码)㈠、数据结构与核心算法的设计描述(程序中每个模块或函数应加注释,说明函数功能、入口及出口参数)1、单链表的结点类型定义/* 定义DataType为int类型 */typedef int DataType;/* 单链表的结点类型 */typedef struct LNode{ DataType data;struct LNode *next;}LNode,*LinkedList;2、初始化单链表LinkedList LinkedListInit( ){ // 每个模块或函数应加注释,说明函数功能、入口及出口参数 }3、清空单链表void LinkedListClear(LinkedList L){// 每个模块或函数应加注释,说明函数功能、入口及出口参数}4、检查单链表是否为空int LinkedListEmpty(LinkedList L){ …. }5、遍历单链表void LinkedListTraverse(LinkedList L){….}6、求单链表的长度int LinkedListLength(LinkedList L){ …. }7、从单链表表中查找元素LinkedList LinkedListGet(LinkedList L,int i){ //L是带头结点的链表的头指针,返回第 i 个元素 }8、从单链表表中查找与给定元素值相同的元素在链表中的位置LinkedList LinkedListLocate(LinkedList L, DataType x){ …… }9、向单链表中插入元素void LinkedListInsert(LinkedList L,int i,DataType x) { // L 为带头结点的单链表的头指针,本算法// 在链表中第i 个结点之前插入新的元素 x}10、从单链表中删除元素void LinkedListDel(LinkedList L,DataType x){ // 删除以 L 为头指针的单链表中第 i 个结点 }11、用尾插法建立单链表LinkedList LinkedListCreat( ){ …… }㈡、函数调用及主函数设计(可用函数的调用关系图说明)㈢程序调试及运行结果分析㈣实验总结五、主要算法流程图及程序清单1、主要算法流程图:2、程序清单(程序过长,可附主要部分)说明:以后每次实验报告均按此格式书写。

数据结构实验实训报告范文

数据结构实验实训报告范文

一、实验目的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、实验内容2.1 实验一、线性表的基本操作2.1.1 实验介绍在本实验中,我们将实现线性表的基本操作,包括初始化线性表、插入元素、删除元素、查找元素等。

通过这些基本操作的实现,我们可以加深对线性表的理解。

2.1.2 实验步骤步骤一、初始化线性表步骤二、插入元素步骤三、删除元素步骤四、查找元素2.2 实验二、栈的应用——括号匹配2.2.1 实验介绍在本实验中,我们将使用栈来实现括号匹配。

通过这个应用实例,我们可以更好地理解栈的特性和应用场景。

2.2.2 实验步骤步骤一、括号匹配算法的实现步骤二、测试括号匹配算法3、实验结果与分析3.1 实验一结果分析3.1.1 初始化线性表的效率分析3.1.2 插入操作的效率分析3.1.3 删除操作的效率分析3.1.4 查找操作的效率分析3.2 实验二结果分析3.2.1 括号匹配算法的验证3.2.2 算法的时间复杂度分析3.2.3 算法的空间复杂度分析4、实验总结通过本次实验,我们进一步了解了数据结构的基本概念和应用。

我们通过实际操作和代码编写,加深了对线性表和栈的理解,并且掌握了相关算法的实现和分析方法。

5、附件本实验报告涉及的附件包括:- 代码实现文件- 实验数据统计表格6、法律名词及注释在本文档中,涉及的法律名词和注释包括:- 数据结构:指在计算机科学中,我们用来组织和存储数据的方式或格式。

- 线性表:是最基本、最简单、也是最常用的一种数据结构。

线性表中的数据元素之间是一对一的关系。

- 栈:是一种特殊的线性表,它的插入和删除操作只能在同一端进行。

后进先出(Last In First Out,LIFO)是栈的特性之一。

- 括号匹配:是指检查一个字符串中的所有括号是否匹配完整的过程。

《数据结构》项目实验报告格式

《数据结构》项目实验报告格式

《***》项目实验报告1、实验名称2、小组成员3、主要内容和步骤:(1)分析问题描述,明确问题目标[问题描述] 1976年。

美国科学家APPEL和HAKEN利用计算机证明了:对一张地图,可以用不超过4种颜色对其填色,使得相邻的区域填上不同的颜色。

要求输入一张行政区地图,用4种颜色对其填色,要求相邻的行政区域内没有相同的颜色,给出所有的填色方案,并统计方案的个数。

(2)分析问题数据描述[数据描述] 首先考虑如何存储行政区域图,由于邻接矩阵能更好地描述各行政区之间的关系,所以采用邻接矩阵G来存储地图。

G[I,J]=1表示I,J两个行政区相邻,为0表示不相邻可采用二维数组来表示邻接矩阵G;另外设一数级COLOR[I]记录各行政区域所填颜色,分别取值为{1(红色),2(黄色),3(蓝色),4(绿色)};数据描述如下:INT G[N][N];//存储地图INT COLOR[N+1];//存储地图各行政区颜色(3)确定算法思路,准确描述算法[算法描述] 对每一个行政区试填一种颜色,确定其合法性,如合法则填下一行政区,如非法则填下一种颜色,如4种颜色均填完仍不合法,则回到上一结点填另一种颜色。

COLOR[0..N-1]=0;选择第一个行政区为首先处理区域;DO{将当前区域顺序向后填一种颜色;IF (所填颜色合法){ 当前区域确定了所填颜色;IF (当前区域是最后一个区域){打印一种填色方案;IF (所填颜色是第4种颜色)回溯到上一个结点继续填色;} ELSE选择下一个行政区作为处理区域;}ELSEIF (所填颜色是第4种颜色)回溯到上一个结点继续填色;} WHILE (所有的方案全部确定)(4)运行数据记录略(5)实验效果图示略(6)实验总结:(心得体会、处理结果、存在的问题、建议和意见等)略。

数据结构实验报告2篇

数据结构实验报告2篇

数据结构实验报告数据结构实验报告精选2篇(一)实验目的:1. 熟悉数据结构的基本概念和基本操作;2. 掌握线性表、栈、队列、链表等经典数据结构的实现方法;3. 掌握数据结构在实际问题中的应用。

实验内容:本次实验主要包括以下几个部分:1. 线性表的实现方法,包括顺序表和链表,分别使用数组和链表来实现线性表的基本操作;2. 栈的实现方法,包括顺序栈和链式栈,分别使用数组和链表来实现栈的基本操作;3. 队列的实现方法,包括顺序队列和链式队列,分别使用数组和链表来实现队列的基本操作;4. 链表的实现方法,包括单链表、双链表和循环链表,分别使用指针链、双向链和循环链来实现链表的基本操作;5. 综合应用,使用各种数据结构来解决实际问题,例如使用栈来实现括号匹配、使用队列来实现马铃薯游戏等。

实验步骤及结果:1. 线性表的实现方法:a) 顺序表的基本操作:创建表、插入元素、删除元素、查找元素等;b) 链表的基本操作:插入节点、删除节点、查找节点等;c) 比较顺序表和链表的优缺点,分析适用场景。

结果:通过实验,确认了顺序表适用于频繁查找元素的情况,而链表适用于频繁插入和删除节点的情况。

2. 栈的实现方法:a) 顺序栈的基本操作:进栈、出栈、判空、判满等;b) 链式栈的基本操作:进栈、出栈、判空、判满等。

结果:通过实验,掌握了栈的基本操作,并了解了栈的特性和应用场景,例如括号匹配。

3. 队列的实现方法:a) 顺序队列的基本操作:入队、出队、判空、判满等;b) 链式队列的基本操作:入队、出队、判空、判满等。

结果:通过实验,掌握了队列的基本操作,并了解了队列的特性和应用场景,例如马铃薯游戏。

4. 链表的实现方法:a) 单链表的基本操作:插入节点、删除节点、查找节点等;b) 双链表的基本操作:插入节点、删除节点、查找节点等;c) 循环链表的基本操作:插入节点、删除节点、查找节点等。

结果:通过实验,掌握了链表的基本操作,并了解了链表的特性和应用场景。

《数据结构》实验报告参考模板

图的创建与遍历.一、实验目的1.掌握图的含义;2.掌握用邻接矩阵和邻接表的方法描述图的存储结构;3.理解并掌握深度优先遍历和广度优先遍历的存储结构。

二、实验要求1.认真阅读和掌握本实验的参考程序。

2.按照对图的操作需要,在创建好图后再通过遍历算法验证创建结果。

3.保存程序的运行结果,并结合程序进行分析。

三、实验内容以下参考程序是按邻接表的方法创建图,然后用深度优先遍历方法遍历图。

请认真理解程序,然后实现图的广度优先遍历。

四、程序流程图、算法及运行结果5-1#include "stdio.h"#define maxsize 1024 /*假定线性表的最大长度为1024*/#define n 100 /* 图的顶点最大个数 */typedef int datatype; /*假定线性表元素的类型为整型*/typedef char VEXTYPE; /* 顶点的数据类型 */typedef float ADJTYPE; /* 权值类型 */typedef struct{VEXTYPE vexs[n] ; /* 顶点信息数组 */ADJTYPE arcs[n][n] ; /* 边权数组 */int num ; /* 顶点的实际个数 */} GRAPH;/* 1.置空图 */void GraphInit(GRAPH *L){L->num=0;}/* 2.求结点数 */int GraphVexs(GRAPH *L){return(L->num);}/* 3.创建图 */void GraphCreate(GRAPH *L){int i,j;GraphInit(L);printf("请输入顶点数目:");scanf("%d",&L->num);printf("请输入各顶点的信息(单个符号):");for(i=0;i<L->num;i++){fflush(stdin);scanf("%c",&L->vexs[i]);}printf("请输入边权矩阵的信息:");for(i=0;i<L->num;i++){for(j=0;j<L->num;j++){scanf("%f",&L->arcs[i][j]);}}printf("图已经创建完毕!");}/* 4.图的输出 */void GraphOut(GRAPH L){int i,j;printf("\n图的顶点数目为:%d",L.num);printf("\n图的各顶点的信息为:\n");for(i=0;i<L.num;i++)printf("%c ",L.vexs[i]);printf("\n图的边权矩阵的信息为:\n");for(i=0;i<L.num;i++){for(j=0;j<L.num;j++){printf("%6.2f ",L.arcs[i][j]);}printf("\n");}printf("图已经输出完毕!");}/* 5.图的深度周游 */void DFS(GRAPH g,int qidian,int mark[])/* 从第qidian个点出发深度优先周游图g中能访问的各个顶点 */ {int v1;mark[qidian]=1;printf("%c ",g.vexs[qidian]);for(v1=0;v1<g.num;v1++){if(g.arcs[qidian][v1]!=0&&mark[v1]==0)DFS(g,v1,mark);}}/* 6.图的深度周游 */void GraphDFS(GRAPH g)/* 深度优先周游图g中能访问的各个顶点 */{int qidian,v,v1,mark[maxsize];printf("\n深度周游:");printf("\n请输入起点的下标:");scanf("%d",&qidian);for(v=0;v<g.num;v++){mark[v]=0;}for(v=qidian;v<g.num+qidian;v++){v1=v%g.num;if(mark[v1]==0)DFS(g,v1,mark);}}/* 队列元素的数据类型 */typedef int DATATYPE;typedef struct{DATATYPE data[maxsize]; /* 队中元素 */int front,rear; /* 队头元素下标、队尾元素后面位置的下标 */} SEQQUEUE;void QueueInit(SEQQUEUE *sq)/* 将顺序循环队列sq置空(初始化) */{sq->front=0;sq->rear=0;}int QueueIsEmpty(SEQQUEUE sq)/* 如果顺序循环队列sq为空,成功返回1,否则返回0 */{if (sq.rear==sq.front)return(1);elsereturn(0);}int QueueFront(SEQQUEUE sq,DATATYPE *e)/* 将顺序循环队列sq的队头元素保存到e所指地址,成功返回1,失败返回0 */ {if(QueueIsEmpty(sq)){ printf("queue is empty!\n");return 0;}else{ *e=sq.data[(sq.front)]; return 1;}}int QueueIn (SEQQUEUE *sq,DATATYPE x)/* 将元素x入队列sq的队尾,成功返回1,失败返回0 */ {if (sq->front==(sq->rear+1)%maxsize){printf("queue is full!\n");return 0;}else{sq->data[sq->rear]=x;sq->rear=(sq->rear+1)%maxsize;return(1);}}int QueueOut(SEQQUEUE *sq)/* 将队列sq队首元素出队列,成功返回1,失败返回0 */ {if(QueueIsEmpty(*sq)){printf("queue is empty!\n");return 0;}else{sq->front=(sq->front+1)%maxsize;return 1;}}/* 7.图的广度周游 */void BFS(GRAPH g,int v,int mark[])/* 从v出发广度优先周游图g中能访问的各个顶点 */ {int v1,v2;SEQQUEUE q;QueueInit(&q);QueueIn(&q,v);mark[v]=1;printf("%c ",g.vexs[v]);while(QueueIsEmpty(q)==0){QueueFront(q,&v1);QueueOut(&q);for(v2=0;v2<g.num;v2++){if(g.arcs[v1][v2]!=0&&mark[v2]==0){QueueIn(&q,v2);mark[v2]=1;printf("%c ",g.vexs[v2]); }}}}/* 8.图的广度周游 */void GraphBFS(GRAPH g)/* 深度优先周游图g中能访问的各个顶点 */ {int qidian,v,v1,mark[maxsize];printf("\n广度周游:");printf("\n请输入起点的下标:");scanf("%d",&qidian);for(v=0;v<g.num;v++){mark[v]=0;}for(v=qidian;v<g.num+qidian;v++){v1=v%g.num;if(mark[v1]==0)BFS(g,v1,mark);}}void main(){GRAPH tu;GraphCreate(&tu);GraphOut(tu);GraphDFS(tu);GraphBFS(tu);}友情提示:范文可能无法思考和涵盖全面,供参考!最好找专业人士起草或审核后使用,感谢您的下载!。

数据结构实验报告模板

实验名称:_________________________实验日期:_________________________实验地点:_________________________一、实验目的1. 理解并掌握_________________________数据结构的基本概念和操作方法。

2. 培养使用_________________________数据结构解决实际问题的能力。

3. 熟悉_________________________编程语言的编程技巧和调试方法。

二、实验原理简要介绍_________________________数据结构的基本原理,包括其定义、特点、优缺点等。

三、实验内容1. 实验环境(1)编程语言:_________________________(2)开发工具:_________________________(3)实验数据:_________________________2. 实验步骤(1)创建_________________________数据结构具体步骤如下:1)初始化_________________________数据结构;2)根据需要添加元素或修改元素;3)进行_________________________操作。

(2)实现_________________________操作具体步骤如下:1)编写_________________________操作的函数;2)对_________________________操作进行测试;3)分析_________________________操作的效率和稳定性。

(3)应用_________________________数据结构解决实际问题具体步骤如下:1)根据实际问题设计_________________________数据结构;2)实现_________________________数据结构的相关操作;3)分析_________________________数据结构在实际问题中的应用效果。

数据结构的实验报告

一、实验目的本次实验旨在让学生掌握数据结构的基本概念、逻辑结构、存储结构以及各种基本操作,并通过实际编程操作,加深对数据结构理论知识的理解,提高编程能力和算法设计能力。

二、实验内容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一﹑实验名称:实验一——链表二﹑实验目的:1.了解线性表的逻辑结构特性;2.熟悉链表的基本运算在顺序存储结构上的实现,熟练掌握链式存储结构的描述方法;3.掌握链表的基本操作(建表、插入、删除等)4. 掌握循环链表的概念,加深对链表的本质的理解。

5.掌握运用上机调试链表的基本方法三﹑实验内容:(1)创建一个链表(2)在链表中插入元素(3)在链表中删除一个元素(4)销毁链表四﹑实验步骤与程序#include <iostream.h>#include <malloc.h>typedef struct LNode{int data;struct LNode *next;}Lnode, *LinkList;//假设下面的链表均为带头结点。

void CreatLinkList(LinkList &L,int j){//建立一个链表L,数据为整数,数据由键盘随机输入。

LinkList p,q;L=(LinkList )malloc(sizeof(Lnode));L->next=NULL;q=L;cout<<"请输入一个链表:"<<endl;for(int i=0;i<j;i++){ p=(LinkList)malloc(sizeof(Lnode));cin>>p->data;p->next=q->next;q->next=p;q=p;}}int PrintLinkList(LinkList &L){//输出链表L的数据元素LinkList p;p=L->next;if(L->next==NULL){cout<<"链表没有元素!"<<endl;return 0;}cout<<"链表的数据元素为:";while(p){cout<<p->data<<" ";p=p->next;}cout<<endl;return 1;}void LinkListLengh(LinkList &L){//计算链表L的数据元素个数。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

数据结构实验报告
顺序表实验
1.实验目标
a.熟练掌握线性表的顺序存储结构。

b.熟练掌握顺序表的有关算法设计。

c.根据具体问题的需要,设计出合理的表示数据的顺序结构,并设计相关算法。

2.实验内容和要求
a.顺序表结构和运算定义,算法的实现以库文件方式实现,不得在测试主程序中直接实现;
b.实验程序有较好可读性,各运算和变量的命名直观易懂,符合软件工程要求;
c.程序有适当的注释。

3.数据结构设计
顺序表
4.算法设计
1.i表示要在顺序表中查找的位置,x表示查找到后返回的值。

int search(seqlist A,int i,elementType &x)
{
if(i<1||i>A.Len)//查找的范围不在顺序表中
return 0;
else
{
x=A.data[i-1];//复制要查找的值
return 1;
}
}
2.i表示要在顺序表中插入的位置,x表示要插入的元素。

void insert(seqlist &A,int i,elementType x)
{
if(i<1||i>A.Len)//超出顺序表范围
cout<<"error"<<endl;
else
{
for(int j=A.Len;j>=i;j--)//找到第i-1个结点擦,并后移元素
A.data[j]=A.data[j-1];
A.data[i-1]=x;//插入元素数据
A.Len++;//改变顺序表长度
}
}
3.先利用循环找到顺序表中第i个结点,然后进行删除操作。

void del(seqlist *L,int i)
{
int j;
if(i<1||i>L->Len+1)//超顺序表范围
cout<<"超出表范围"<<endl;
else
{
for(j=i-1;j<L->Len;j++)
L->data[j]=L->data[j+1];//删除第i个结点
L->Len--;
cout<<"删除元素后的表为:";
for(int k=0;k<L->Len;k++)//输出顺序表
cout<<L->data[k]<<" ";
cout<<endl;
}
}
4.因为顺序表是递增有序的,所以利用循环从顺序表的表尾进行比较,比X值大的元素则后移,一直到遇到小于等于X的元素,进行插入操作。

int insertlist(seqlist *L,elementType x)
{
if (L->Len==MAXLEN)
return 0;
else
{
int i=L->Len-1;
L->Len++;
while(x<=L->data[i])
{
L->data[i+1]=L->data[i];//查找待插入的位置
i--;
}
L->data[i+1]=x;//插入元素
return 1;
}
}
5.申请两个新的顺序表,然后对原表进行遍历,由 A.data[i]%2进行及奇偶的分离,并分别存入顺序表B,C中。

void separatelist(seqlist A,seqlist *B,seqlist *C)
{
int b(0),c(0);
for(int i=0;i<A.Len;i++)
{
if(A.data[i]%2)//奇数
{
B->data[b]=A.data[i];
b++;
B->Len++;
}
else//偶数
{
C->data[c]=A.data[i];
c++;
C->Len++;
}
}
}
5.因为顺序表L1和L2是递增有序的,所以对表L1设置个i指示,对表L2设
置个j指示,然后利用循环,如果L1.data[i]==L2.data[j],则复制元素,如果L1.data[i]>L2.data[j],则j++,如果 L1.data[i]<L2.data[j],则i++;
直到其中一表遍历完;
void Newlist(seqlist A,seqlist B,seqlist *L)
{
int i(0),j(0),k(0);
while(i<A.Len&&j<B.Len)
{
if(A.data[i]==B.data[j])
{
L->data[k]=A.data[i];
i++;
j++;
k++;
L->Len++;
}
else if(A.data[i]>B.data[j])
j++;
else
i++;
}
}
6.因为顺序表是递增有序的,所以从顺序表的表尾进行操作,使用双重循环,
如果遇到两元素相等,则进行删除操作,并移动元素,统计移动次数。

void del(seqlist *A,int &n)
{
for(int i=A->Len-1; i>0;i--)
for(int j=i-1;j>=0;j--)
{
if(A->data[i]==A->data[j])
{
for(int k=i;k<A->Len;k++)
{
A->data[k]=A->data[k+1];//删除相同元素
n++;//统计次数
}
A->Len--;
}
}
}
7.运行和测试
1.
2.
3.
4.
5.
6.
7.
8.总结和心得
对于顺序表的基本操作,如查找,插入,删除等,大都是用循环操作来实现的,当然,在进行这些操作时,要时刻注意表中元素的移动及表中元素个数的操作;同时在进行对顺序表的操作时,可以采取指针和地址引用两种方法。

在进行算法的编写时,要注意时间复杂度,尽量少用多重循环。

相关文档
最新文档