当前位置:文档之家› 数据结构各个实验指导书

数据结构各个实验指导书

数据结构各个实验指导书
数据结构各个实验指导书

《数据结构》实验指导书南京工程学院通信工程学院

目录

前言 (1)

实验一线性表的基本操作 (2)

实验二栈、队列的设计实现 (4)

实验三串的模式匹配算法 (6)

实验四二叉树的建立及遍历算法的实现 (8)

实验五图的建立及遍历算法的实现 (11)

实验六哈希表的设计与实现 (14)

实验七排序算法实现 (17)

附录A 实验的步骤和规范 (19)

前言

《数据结构》课程是信息工程、通信工程(计算机通信)专业的重要专业基础课程之一。

本书是为配合《数据结构》实验教学大纲而编写的实验指导书,其目的是使学生消化理论知识,加深对讲授内容的理解,尤其是一些算法的实现及其应用,培养学生独立编程和调试程序的能力,使学生对数据结构有更深刻的认识。

本实验指导书的内容都是基于C语言的,因此,要求学生对C语言和C++中的引用知识点要有一定的了解,建议使用VC++作为实验平台。

希望同学们在使用本实验指导书及进行实验的过程中,能够发现问题,并提出建议。

实验一线性表的基本操作

一、实验目的:

1.熟悉Visual C++ 6.0 IDE开发环境。

2.掌握线性表的顺序与链式存储结构

3.掌握线性表的基本操作:初始化、插入、删除、查找算法。

二、实验内容:

1.定义线性表的链式存储结构

2.在线性表的链式存储结构上,编写函数实现链表的初始化,插入、删除,输出、销毁等算法。

三、实验要求:

1.数据结构定义正确,程序编码规范。

2.撰写实验报告,写出程序运行结果。

3.分析算法,写出本次实验总结。

四、实现提示:

1.数据结构定义

typedef int ElemType;

typedef struct LNode

{ //结点类型

ElemType data;

struct LNode *next;

} LNode, *LinkList;

2.标准库函数malloc,free (相应的头文件 stdlib.h )

p=(LNode *)malloc(sizeof(LNode));该语句的功能是申请分配一个类型为LNode的结点的地址空间,并将首地址存入指针变量p 中。当结点不需要时可以用标准函数free(p)释放结点存储空间,这时p为空值(NULL)。

五、思考与提高

1. 编写函数求链表的长度。

2. 编写函数取得链表的第i个数据元素。

实验二栈、队列的设计实现

一、实验目的

1.掌握栈的顺序表示和基本操作算法

2.掌握队列的链式表示和基本操作算法

二、实验内容:

1.定义顺序栈的数据结构

2.编写函数实现的栈的初始化、入栈、出栈、判断栈是否为空的算法,并应用与表达式的括号匹配检测。

3.定义队列的链式数据结构

4.编写函数实现链队列的入队列、出队列算法

三、实验要求:

1.数据结构定义正确,程序编码规范。

2.撰写实验报告,写出程序运行结果。

3.分析算法,写出本次实验总结。

四、实现提示

1.顺序栈的数据结构

#define STACK_INIT_SIZE 100

#define STACKINCREMENT 10

typedef int SElemType;

typedef struct

{

SElemType *base;

SElemType *top;

int stacksize;

}SqStack;

2.表达式的括号匹配算法提示

int match (char *expr)

{ SqStack S;

int i,len;

int temp;

InitStack(S);

len=strlen(expr);

for(i=0;i

{

if( expr[i]=='(' )

Push(S,expr[i]);

if( expr[i]==')' )

if(!Pop(S,temp))

return 0;

}

if(EmptyStack(S))

return 1;

else

return 0;

}

如:(3+4)*12+(5-6)/2 match (3+4)*12)+(5-6)/2) not match 五、思考与提高

1.用栈实现进制转换(十进制转换成二进制)2.模拟服务台前的排队现象问题

实验三串的模式匹配算法

一、实验目的:

1.掌握串的顺序存储结构

2.掌握串的基本算法

二、实验内容:

1.定义串的顺序存储结构。

2.编写函数实现串的初始化、分配、取子串算法

3.编写函数据实现串的模式匹配

三、实验要求:

1.数据结构定义正确,程序编码规范。

2.撰写实验报告,写出程序运行结果。

3.分析算法,写出本次实验总结。

四、实现提示

1.数据结构

typedef struct

{

char *ch;

int length;

}HString;

2.串的简单模式匹配算法

int Index(HString S,HString T,int pos)

{

int i,j,k;

k=pos-1; //记录初始比较位置

i=pos-1;

j=0;

while(i

{

if(S.ch[i]==T.ch[j])

{

i++;

j++;

}

else

{

k++;

i=k;

j=0;

}

}

if(j>=T.length)

return(k+1);

else

return 0;

}

五、思考与提高

1.如何对串的简单模式匹配算法进行改进,提高算法效率。

实验四二叉树的建立及遍历算法的实现

一、实验目的:

1. 通过实验,掌握二叉树的建立与存储

2. 通过实验,掌握二叉树的遍历算法

二、实验内容:

1.定义二叉树的链式数据结构。

2.编写函数,创建下图所示的二叉树。

3.编写函数输出二叉树的先序、中序、后序遍历。

三、实验要求:

1.数据结构定义正确,程序编码规范。

2.撰写实验报告,写出程序运行结果。

3.分析算法,写出本次实验总结。

四、实现提示

1.数据结构

typedef int TElemtype;

typedef struct BiNode

{

TElemtype data;

struct BiNode *lchild,*rchild;

}BiNode,*BiTree;

2.创建二叉树算法

int CreateBiTree(BiTree &BT)

{

char ch;

scanf("%c",&ch);

if (ch==' ')

BT=NULL; //构造空树

else

{

BT=(BiNode *)malloc(sizeof(BiNode));

if(!BT)

return 0;

BT->data=ch;

CreateBiTree (BT->lchild );

CreateBiTree (BT->rchild );

}

return 1;

}

五、思考与提高

1.编写函数,求二叉树叶子结点个数。

2.编写函数,求二叉树的高度。

注:算法提示(利用递归特性)

// 二叉树高度算法

int treeHeight(BiTree BT)

{

int h1,h2;

if(BT==NULL) return 0;

else

{

h1=treeHeight(BT->lchild);

h2=treeHeight(BT->rchild);

if(h1>h2)

return h1+1;

else

return h2+1;

}

}

int leafCount(BiTree BT)

{

/* 叶子结点计算器,声明:static */

static int count=0;

if (BT)

{

leafCount(BT->lchild);

if (BT->lchild==NULL&&BT->rchild==NULL) count++;

leafCount(BT->rchild);

}

return count;

}

实验五图的建立及遍历算法的实现

一、实验目的:

1.掌握图的定义及图的存储结构。

2.掌握图的遍历算法

二、实验内容:

1.定义图的数据结构。

2.编写函数,用邻接表实现图的存储结构,求图的顶点的度数。

3.编写函数,输出图的遍历序列。

三、实验要求:

1.数据结构定义正确,程序编码规范。

2.撰写实验报告,写出程序运行结果。

3.分析算法,写出本次实验总结。

四、实现提示

1.数据结构定义

#define MAX_VERTEX_NUM 100 /*最大顶点数为100*/

int visited[MAX_VERTEX_NUM];

typedef int VertexType;

/*表结点*/

typedef struct ArcNode

{

int adjvex;

struct ArcNode * nextarc;

}ArcNode;

/*头结点*/

typedef struct VNode

{

VertexType data;

ArcNode * firstarc;

}VNode,AdjList[MAX_VERTEX_NUM];

typedef struct

{

AdjList vertices;

int vexnum,arcnum;

}ALGraph;

2.图的存储(邻接表存储)

void CreateALGraph(ALGraph &G)

{

int i,j,k;

ArcNode *s;

printf("input data:顶点数,边数:\n");

scanf("%d,%d",&G.vexnum,&G.arcnum);

printf("\nplease v data:");

for(i=0;i

{

scanf("%d",&G.vertices[i].data);

G.vertices[i].firstarc=NULL;

}

for(k=0;k

{

printf("please input arc ");

scanf("%d,%d",&i,&j);

s=(ArcNode*)malloc(sizeof(ArcNode));

s->adjvex=j;

s->nextarc=G.vertices[i].firstarc;

G.vertices[i].firstarc=s;

}

}

五、思考与提高

1.判断两点是否可以到达。

实验六哈希表的设计与实现

一、实验目的:

1.掌握哈希表、哈希函数及解决冲突的方法。

2.掌握哈希查找、平均查找长度ASL

二、实验内容:

1.定义哈希表数据结构。

2.除留余数法做为哈希函数、

H(key) = key % P

用线性探测再散列解决冲突方法,编写函数,实现哈希造表的过程,并输出哈希表。

3.编写函数,求查找成功时的平均查找长度(ASL)。

三、实验要求:

1.数据结构定义正确,程序编码规范。

2.撰写实验报告,写出程序运行结果。

3.分析算法,写出本次实验总结。

四、实现提示

1.数据结构

#define hashlen 11 //哈希表长

Int h[hashlen]={0}; //初始哈希表

int status[hashlen]={0}; //状态数组

int data[9]={20,30,70,15,8,12,18,63,19}; //初始数据元素,将该数据元素散列到哈希表中。

2.哈希造表算法

int hash_create(int h[],int status[],int data)/*哈希造表*/ {

int address;

int di;

address=data%p;

if(status[address]==0)

{

h[address]=data;

status[address]=1;

}

else

{

// 冲突,线性探测再散列

for(di=1;di<=hashlen-1;di++)

{

address=((data%p)+di)%hashlen;

if(status[address] = = 0)

{

h[address]=data;

status[address]=1;

break;

}

}

}

return 1;

}

五、思考与提高

1.哈希造表算法中,int status[]作用是什么?

2.哈希造表函数不变,采用链地址法做为解决冲突的方法,求查找成功时的平均查找长度(ASL),两者有什么区别,做一下对比分析。

实验七排序算法实现

一、实验目的:

1. 掌握常用的排序方法,并掌握用高级语言实现排序算法的方法;

2. 深刻理解排序的定义和各种排序方法的特点,并能加以灵活应用;

3. 了解各种方法的排序过程及其时间复杂度的分析方法。

二、实验内容:

1.定义数据结构。

2.编写函数,实现插入排序算法。

3.编写函数,实现希尔排序或快速排序等效率较高的算法。

三、实验要求:

1.数据结构定义正确,程序编码规范。

2.撰写实验报告,写出程序运行结果。

3.分析算法,写出本次实验总结。

四、实现提示

1.数据结构定义

#define MAXSIZE 100

typedef struct

{

int r[MAXSIZE+1]; // 0号单元空出,

int length;

}SqList;

2.复习学过的选择法、起泡法排序算法

3.// insert sort

void InsertSort(SqList &L)

{

int i,j;

for(i=2;i<=L.length;i++)

{

if(L.r[i]

{

L.r[0]=L.r[i];

L.r[i]=L.r[i-1];

for(j=i-2; L.r[0]

L.r[j+1]=L.r[j];

L.r[j+1]=L.r[0];

}

}

}

五、思考与提高

1.编程实现,堆排序算法

数据结构课程实验指导书

数据结构实验指导书 一、实验目的 《数据结构》是计算机学科一门重要的专业基础课程,也是计算机学科的一门核心课程。本课程较为系统地论述了软件设计中常用的数据结构以及相应的存储结构与实现算法,并做了相应的性能分析和比较,课程内容丰富,理论系统。本课程的学习将为后续课程的学习以及软件设计水平的提高打下良好的基础。 由于以下原因,使得掌握这门课程具有较大的难度: 1)理论艰深,方法灵活,给学习带来困难; 2)内容丰富,涉及的知识较多,学习有一定的难度; 3)侧重于知识的实际应用,要求学生有较好的思维以及较强的分析和解决问题的能力,因而加大了学习的难度; 根据《数据结构》课程本身的特性,通过实验实践内容的训练,突出构造性思维训练的特征,目的是提高学生分析问题,组织数据及设计大型软件的能力。 课程上机实验的目的,不仅仅是验证教材和讲课的内容,检查自己所编的程序是否正确,课程安排的上机实验的目的可以概括为如下几个方面: (1)加深对课堂讲授内容的理解 实验是对学生的一种全面综合训练。是与课堂听讲、自学和练习相辅相成的必不可少的一个教学环节。通常,实验题中的问题比平时的习题复杂得多,也更接近实际。实验着眼于原理与应用的结合点,使学生学会如何把书上学到的知识用于解决实际问题,培养软件工作所需要的动手能力;另一方面,能使书上的知识变" 活" ,起到深化理解和灵活掌握教学内容的目的。 不少学生在解答习题尤其是算法设计时,觉得无从下手。实验中的内容和教科书的内容是密切相关的,解决题目要求所需的各种技术大多可从教科书中找到,只不过其出

现的形式呈多样化,因此需要仔细体会,在反复实践的过程中才能掌握。 (2) 培养学生软件设计的综合能力 平时的练习较偏重于如何编写功能单一的" 小" 算法,而实验题是软件设计的综合训练,包括问题分析、总体结构设计、用户界面设计、程序设计基本技能和技巧,多人合作,以至一整套软件工作规范的训练和科学作风的培养。 通过实验使学生不仅能够深化理解教学内容,进一步提高灵活运用数据结构、算法和程序设计技术的能力,而且可以在需求分析、总体结构设计、算法设计、程序设计、上机操作及程序调试等基本技能方面受到综合训练。实验着眼于原理与应用的结合点,使学生学会如何把书本上和课堂上学到的知识用于解决实际问题,从而培养计算机软件工作所需要的动手能力。 (3) 熟悉程序开发环境,学习上机调试程序一个程序从编辑,编译,连接到运行,都要在一定的外部操作环境下才能进行。所谓" 环境" 就是所用的计算机系统硬件,软件条件,只有学会使用这些环境,才能进行 程序开发工作。通过上机实验,熟练地掌握程序的开发环境,为以后真正编写计算机程序解决实际问题打下基础。同时,在今后遇到其它开发环境时就会触类旁通,很快掌握新系统的使用。 完成程序的编写,决不意味着万事大吉。你认为万无一失的程序,实际上机运行时可能不断出现麻烦。如编译程序检测出一大堆语法错误。有时程序本身不存在语法错误,也能够顺利运行,但是运行结果显然是错误的。开发环境所提供的编译系统无法发现这种程序逻辑错误,只能靠自己的上机经验分析判断错误所在。程序的调试是一个技巧性很强的工作,尽快掌握程序调试方法是非常重要的。分析问题,选择算法,编好程序,只能说完成一半工作,另一半工作就是调试程序,运行程序并得到正确结果。 二、实验要求 常用的软件开发方法,是将软件开发过程划分为分析、设计、实现和维护四个阶段。虽然数据结构课程中的实验题目的远不如从实际问题中的复杂程度度高,但为了培养一个软件工作者所应具备的科学工作的方法和作风,也应遵循以下五个步骤来完成实验题目: 1) 问题分析和任务定义 在进行设计之前,首先应该充分地分析和理解问题,明确问题要求做什么?限制条件是什么。本步骤强调的是做什么?而不是怎么做。对问题的描述应避开算法和所涉及的数据类型,而是对所需完成的任务作出明确的回答。例如:输入数据的类型、值的范围以及输入的

数据结构实验指导书(2016.03.11)

《数据结构》实验指导书 郑州轻工业学院 2016.02.20

目录 前言 (3) 实验01 顺序表的基本操作 (7) 实验02 单链表的基本操作 (19) 实验03 栈的基本操作 (32) 实验04 队列的基本操作 (35) 实验05 二叉树的基本操作 (38) 实验06 哈夫曼编码 (40) 实验07 图的两种存储和遍历 (42) 实验08 最小生成树、拓扑排序和最短路径 (46) 实验09 二叉排序树的基本操作 (48) 实验10 哈希表的生成 (50) 实验11 常用的内部排序算法 (52) 附:实验报告模板 .......... 错误!未定义书签。

前言 《数据结构》是计算机相关专业的一门核心基础课程,是编译原理、操作系统、数据库系统及其它系统程序和大型应用程序开发的重要基础,也是很多高校考研专业课之一。它主要介绍线性结构、树型结构、图状结构三种逻辑结构的特点和在计算机内的存储方法,并在此基础上介绍一些典型算法及其时、空效率分析。这门课程的主要任务是研究数据的逻辑关系以及这种逻辑关系在计算机中的表示、存储和运算,培养学生能够设计有效表达和简化算法的数据结构,从而提高其程序设计能力。通过学习,要求学生能够掌握各种数据结构的特点、存储表示和典型算法的设计思想及程序实现,能够根据实际问题选取合适的数据表达和存储方案,设计出简洁、高效、实用的算法,为后续课程的学习及软件开发打下良好的基础。另外本课程的学习过程也是进行复杂程序设计的训练过程,通过算法设计和上机实践的训练,能够培养学生的数据抽象能力和程序设计能力。学习这门课程,习题和实验是两个关键环节。学生理解算法,上机实验是最佳的途径之一。因此,实验环节的好坏是学生能否学好《数据结构》的关键。为了更好地配合学生实验,特编写实验指导书。 一、实验目的 本课程实验主要是为了原理和应用的结合,通过实验一方面使学生更好的理解数据结构的概念

工程结构试验与检测课程实验教学大纲

《工程结构试验与检测》课程实验教学大纲 (Engineering Structure Experimentation and Measuring) 一、基本信息 课程编号:G1113106 课程类别:专业教育必修课 适用层次:本科 适用专业:土木工程、工程管理 开课学期:6 总学分:0.5 总学时:8学时 考核方式:考查 二、教学目的 《工程结构试验与检测》是一门实践性很强的课程,实验是这门课的一个重要组成部分,学生实验的目的在于:一是熟悉、验证、巩固所学的理论知识,增加感性认识;二是了解所使用的仪器设备,掌握所学建筑各种结构的试验方法;三是进行科学研究的基本训练,培养分析问题和解决问题的能力;四是培养学生严肃认真实事求是的学风。 三、基本要求 实验课是教学的重要环节之一,在实验过程中,对于仪器操作、记录格式、试验成果的检核、计算等,应向学生提严格要求。对具体的实验内容要求见表1。

表1 试验内容与要求 四、实验内容 本课程实验以在实验室试验为主,以多媒体教学和现场观察测试为辅。实验主要包括六个实验内容,除必修实验外(实验一、五),学生可以在选修实验(实验二、三、四、六)中任选一个实验。 实验一电阻应变片的粘贴、静态电阻应变仪的使用及桥路连接试验 实验目的: (1)参观试验室,了解基本的大型试验仪器,了解试验的基本过程; (2)掌握应变片的粘贴技术,学会防潮层的制作; (3)掌握半桥、全桥及四分之一桥的接法; (4)掌握静态电阻应变仪的使用。 实验要求和实验内容: (1)正确处理基层、会进行应变片的粘贴与防潮; (2)学会单点、多点测量方法,半桥、全桥接法及四分之一桥接法;

数据结构实验报告代码

线性表 代码一 #include "stdio.h" #include "malloc.h" #define OK 1 #define ERROR 0 #define OVERFLOW -2 #define LIST_INIT_SIZE 100 #define LISTINCREMENT 10 typedef struct { int * elem; int length; int listsize; }SqList; int InitList_Sq(SqList *L) { L->elem = (int*)malloc(LIST_INIT_SIZE*sizeof(int)); if (!L->elem) return ERROR; L->length = 0; L->listsize = LIST_INIT_SIZE; return OK; } int ListInsert_Sq(SqList *L, int i,int e) { int *p,*newbase,*q; if (i < 1 || i > L->length+1) return ERROR; if (L->length >= L->listsize) { newbase = (int *)realloc(L->elem,(L->listsize+LISTINCREMENT)*sizeof (int)); if (!newbase) return ERROR; L->elem = newbase; L->listsize += LISTINCREMENT; } q = &(L->elem[i-1]); //插入后元素后移for(p=&(L->elem[L->length-1]);p>=q;p--) *(p+1)=*p; *q=e; L->length++; return OK; } int ListDelete_Sq(SqList *L, int i, int *e) {

数据结构实验指导书

《数据结构》实验指导书 实验一顺序表 实验目的: 熟悉顺序表的逻辑特性、存储表示方法和顺序表的基本操作。 实验要求: 了解并熟悉顺序表的逻辑特性、存储表示方法和顺序表的基本操作的实现和应用。 实验内容: 1、编写程序实现在线性表中找出最大的和最小的数据元素,并符合下列要求: (1)设数据元素为整数,实现线性表的顺序存储表示。 (2)从键盘输入10个数据元素,利用顺序表的基本操作建立该表。 (3)利用顺序表的基本操作,找出表中最大的和最小的数据元素(用于比较的字段为整数)。 2、编写一个程序实现在学生成绩中找出最高分和最低分,并符合下列要求: (1)数据元素为学生成绩(含姓名、成绩等字段)。 (2)要求尽可能少地修改第一题的程序来得到此题的新程序,即要符合第一题的所有要求。(这里用于比较的字段为分数) 实验二链表 实验目的: 熟悉链表的逻辑特性、存储表示方法的特点和链式表的基本操作。 实验要求: 了解并熟悉链式表的逻辑特性、存储表示方法和链式表的基本操作的实现和应用。

实验内容: 1、编写一个程序建立存放学生成绩的有序链表并实现相关操作,要求如下: (1)设学生成绩表中的数据元素由学生姓名和学生成绩字段组成,实现这样的线性表的链式存储表示。 (2)键盘输入10个(或若干个,特殊数据来标记输入数据的结束)数据元素,利用链表的基本操作建立学生成绩单链表,要求该表为有序表 并带有头结点。(用于比较的字段为分数)。 (3)输入关键字值x,打印出表中所有关键字值<=x的结点。(用于比较的关键字字段为分数)。 (4)输入关键字值x,删除表中所有关键字值<=x的结点。(用于比较的关键字字段为分数)。 (5)输入关键字值x,并插入到表中,使所在的链表仍为有序表。(用于比较的字段为分数)。 实验三栈的应用 实验目的: 熟悉栈的逻辑特性、存储表示方法和栈的基本操作。 实验要求: 了解并熟悉栈的逻辑特性、顺序和链式存储表示方法和栈的基本操作的实现和应用。 实验内容: (1)判断一个表达式中的括号(仅有一种括号,小、中或大括号) 是否配对。编写并实现它的算法。 (2)用不同的存储方法,求解上面的问题。 (3)* 若表达式中既有小括号,又有大括号(或中括号),且允许 互相嵌套,但不能交叉,写出判断这样的表达式是否合法的算 法。如 2+3*(4-{5+2}*3)为合法;2+3*(4-{5+2 * 3} 、 2+3*(4-[5+2 * 3)为不合法。

2017数据结构实验指导书

《数据结构》实验指导书 贵州大学 电子信息学院 通信工程

目录 实验一顺序表的操作 (3) 实验二链表操作 (8) 实验三集合、稀疏矩阵和广义表 (19) 实验四栈和队列 (42) 实验五二叉树操作、图形或网状结构 (55) 实验六查找、排序 (88) 贵州大学实验报告 (109)

实验一顺序表的操作 实验学时:2学时 实验类型:验证 实验要求:必修 一、实验目的和要求 1、熟练掌握线性表的基本操作在顺序存储和链式存储上的实现。 2、以线性表的各种操作(建立、插入、删除等)的实现为重点。 3、掌握线性表的动态分配顺序存储结构的定义和基本操作的实现。 二、实验内容及步骤要求 1、定义顺序表类型,输入一组整型数据,建立顺序表。 typedef int ElemType; //定义顺序表 struct List{ ElemType *list; int Size; int MaxSize; }; 2、实现该线性表的删除。 3、实现该线性表的插入。 4、实现线性表中数据的显示。 5、实现线性表数据的定位和查找。 6、编写一个主函数,调试上述算法。 7、完成实验报告。 三、实验原理、方法和手段 1、根据实验内容编程,上机调试、得出正确的运行程序。 2、编译运行程序,观察运行情况和输出结果。 四、实验条件 运行Visual c++的微机一台 五、实验结果与分析 对程序进行调试,并将运行结果进行截图、对所得到的的结果分析。 六、实验总结 记录实验感受、上机过程中遇到的困难及解决办法、遗留的问题、意见和建议等,并将其写入实验报告中。

【附录----源程序】 #include #include using namespace std; typedef int ElemType; struct List { ElemType *list; int Size; int MaxSize; }; //初始化线性表 bool InitList(List &L) { L.MaxSize=20; L.list=new ElemType[L.MaxSize]; for(int i=0;i<20&&L.list==NULL;i++) { L.list=new ElemType[L.MaxSize]; } if(L.list==NULL) { cout<<"无法分配内存空间,退出程序"<L.Size+1||pos<1) { cout<<"位置无效"<

数据结构实验一的源代码

#include #include typedef struct Node { int key;//密码 int num;//编号 struct Node *next;//指向下一个节点 } Node, *Link; void InitList(Link &L) //创建一个空的链表{ L = (Node *)malloc(sizeof(Node)); if (!L) exit(1); L->key = 0; L->num = 0; L->next = L; } void Creatlinklist(int n, Link &L) //初始化链表{ Link p, q; q = L; for (int i = 1; i <= n; i++) { p = (Node *)malloc(sizeof(Node)); if (!p) exit(1); scanf("%d", &p->key); p->num = i; L->next = p; L = p; } L->next = q->next; free(q); } Link Locate_m(Link &p, int m)//找到第m个 { Link q; for (int j = 1; jnext; q = p->next; m = q->key;

return q; } void Delete_m(Link &L, Link p, Link q)//删除第m个{ p->next = q->next; free(q); } void main() { Link L, p, q; int n, m; L = NULL; InitList(L);//构造出一个只有头结点的空链表 printf("请输入初始密码人数每个人的密码:\n"); scanf("%d", &m);//初始密码为m scanf("%d", &n);// Creatlinklist(n, L);//构建 p = L; for (int i = 1; i <= n; i++) { q = Locate_m(p, m);//找到第m个 printf("%d", q->num); Delete_m(L, p, q);//删除第m个 } system("pause"); }

结构试验指导书2015

试验一静态应变测试工艺及静态应变仪的操作方法 一、试验目的及要求 1.掌握电阻应变片的选用原则、方法及其粘贴技术; 2.熟悉静态应变仪的操作规程; 3.掌握静态电阻应变仪单点测量的基本原理; 4.学会电阻应变仪的半桥测量接线方法。 二、试验设备及仪表 电桥 兆欧表 万用电表 粘结剂 电阻应变片 电烙铁及其它工具 导线若干 Bz-2206型静态电阻应变仪 标准钢梁(等强度梁) 三、试验内容及原理 1. 电阻应变片的粘贴技术 (1)、外观检查;用放大镜仔细检查应变片结构,检查丝栅有无短路、有无锈蚀斑痕、有无弯折;测试应变片的阻值,检查其阻值是否和提供的电阻应变片阻值相符; (2)、贴片前表面的处理:将欲贴应变片部位表面用砂纸打光,并将其表面打出与等强度梁轴线成450的细纹,然后用药棉沾丙酮将表面擦洗干净,细至药棉上无污迹为止; (3)、画线定位:在贴片处,根据测量方向定位画线(如图2); (4)、在粘贴应变片处滴一小滴502胶(注意应变片正反面),将应

变片贴在预定位置上,用一小块塑料布盖在应变片上,用手轻轻挤压应变片,将多余的胶水挤出(注意不要让胶水粘在手上); (5)、检查贴片质量:先观察应变片下是否有气泡、漏粘现象,检查引出线是否粘在试件上,再用万用表检查应变片的绝缘度,绝缘度要求大于100MΩ,若不符合要求,则用吹风机烘烤(注意温度不能超过600),若仍不能达到要求,则需要重新贴片; (6)、接线:先贴端子,将应变片的引线、导线分别焊在端子的对应接头上; (7)、在导线的一端进一步检查片子的绝缘度及阻值; (8)、防潮处理:用凡士林把应变片、端子封好; 2. 静态电阻应变仪的操作原理 静态电阻应变仪的读数ε仪与各桥臂应变片的应变值εi有下列关系: ε仪=ε1-ε2-ε3+ε4 半桥接线与测量 如果应变片R1接于应变仪AB接线柱,温度补偿片R2接于BC接线柱,则构成外半桥,如图3;内半桥由应变仪内部两个精密无感绕线电阻组成,应变仪读出的数值为ε仪=ε1。 四、试验步骤 1. 按要求粘贴应变片(轴线上),测量等强度梁的厚度及各部分尺寸; 2. 按半桥接法接通桥路,预调应变仪,使所接测点读数为零,如果实在不能调零,则记下初始读数。 3. 加载试验:分级加载5N、10N、15N、20N、25N、30N共6级。逐级记取读数。 4. 重复上述步骤3次,取每级荷载下应变的平均值。并在每一次试验后记下残余应变值。 五、数据处理与分析

数据结构实验程序

顺序表的基本操作 #include using namespace std; typedef int datatype; #define maxsize 1024 #define NULL -1 typedef struct { datatype *data; int last; }sequenlist; void SETNULL(sequenlist &L) { L.data=new datatype[maxsize]; for(int i=0;i>https://www.doczj.com/doc/4f5396777.html,st; cout<<"请输入"<>L.data[i]; } int LENGTH(sequenlist &L) { int i=0; while(L.data[i]!=NULL) i++; return i; } datatype GET(sequenlist &L,int i) { if(i<1||i>https://www.doczj.com/doc/4f5396777.html,st) { cout<<"error1"<

int j=0; while(L.data[j]!=x) j++; if(j==https://www.doczj.com/doc/4f5396777.html,st) { cout<<"所查找值不存在!"<=maxsize-1) { cout<<"overflow"; return NULL; } else if(i<1||(i>https://www.doczj.com/doc/4f5396777.html,st)) { cout<<"error2"<=i-1;j--) L.data[j+1]=L.data[j]; L.data[i-1]=x; https://www.doczj.com/doc/4f5396777.html,st++; } return 1; } int DELETE(sequenlist &L,int i) { int j; if((i<1)||(i>https://www.doczj.com/doc/4f5396777.html,st+1)) { cout<<"error3"<

《数据结构》实验指导书

《数据结构》实验指导书 实验类别:课内实验实验课程名称:数据结构 实验室名称:软件工程实验室实验课程编号:N02070601 总学时:64 学分: 4 适用专业:计算机科学与技术、网络工程、物联网工程、数字媒体专业 先修课程:计算机科学导论、离散数学 实验在教学培养计划中地位、作用: 数据结构是计算机软件相关专业的主干课程,也是计算机软硬件专业的重要基础课程。数据结构课程实验的目的是通过实验掌握数据结构的基本理论和算法,并运用它们来解决实际问题。数据结构课程实验是提高学生动手能力的重要的实践教学环节,对于培养学生的基本素质以及掌握程序设计的基本技能并养成良好的程序设计习惯方面发挥重要的作用。 实验一线性表的应用(2学时) 1、实验目的 通过本实验,掌握线性表链式存储结构的基本原理和基本运算以及在实际问题中的应用。 2、实验内容 建立某班学生的通讯录,要求用链表存储。 具体功能包括: (1)可以实现插入一个同学的通讯录记录; (2)能够删除某位同学的通讯录; (3)对通讯录打印输出。 3、实验要求 (1)定义通讯录内容的结构体; (2)建立存储通讯录的链表结构并初始化; (3)建立主函数: 1)建立录入函数(返回主界面) 2)建立插入函数(返回主界面) 3)建立删除函数(返回主界面) 4)建立输出和打印函数(返回主界面) I)通过循环对所有成员记录输出 II)输出指定姓名的某个同学的通讯录记录 5)退出 实验二树的应用(2学时) 1、实验目的 通过本实验掌握二叉排序树的建立和排序算法,了解二叉排序树在实际中的应用并熟练运用二叉排序树解决实际问题。 2、实验内容 建立一个由多种化妆品品牌价格组成的二叉排序树,并按照价格从低到高的顺序 打印输出。 3、实验要求 (1)创建化妆品信息的结构体; (2)定义二叉排序树链表的结点结构; (3)依次输入各类化妆品品牌的价格并按二叉排序树的要求创建一个二叉排序树链表;(4)对二叉排序树进行中序遍历输出,打印按价格从低到高顺序排列的化妆品品牌信息。 实验三图的应用(2学时)

数据结构实验指导书及答案(徐州工程学院)

《数据结构实验》实验指导书及答案

信电工程学院计算机科学和技术教研室编 2011.12 数据结构实验所有代码整理 作者郑涛 声明:在这里我整理了数据结构实验的所有代码,希望能对大家的数据结构实验的考试有所帮助,大家可以有选择地浏览,特别针对一些重点知识需要加强记忆(ps:重点知识最好让孙天凯给出),希望大家能够在数据结构实验的考试中取得令人满意的成绩,如果有做的 不好的地方请大家谅解并欢迎予以指正。 实验一熟悉编程环境 实验预备知识: 1.熟悉本课程的语言编译环境(TC或VC),能够用C语言编写完整的程序,并能够发现和改正错误。 2.能够灵活的编写C程序,并能够熟练输入C程序。 一、实验目的 1.熟悉C语言编译环境,掌握C程序的编写、编译、运行和调试过程。 2.能够熟练的将C程序存储到指定位置。 二、实验环境 ⒈硬件:每个学生需配备计算机一台。 ⒉软件:Windows操作系统+Turbo C; 三、实验要求 1.将实验中每个功能用一个函数实现。 2.每个输入前要有输入提示(如:请输入2个整数当中用空格分割:),每个输出数据都要求有内容说明(如:280和100的和是:380。)。 3.函数名称和变量名称等用英文或英文简写(每个单词第一个字母大写)形式说明。 四、实验内容 1.在自己的U盘中建立“姓名+学号”文件夹,并在该文件夹中创建“实验1”文件夹(以后每次实验分别创建对应的文件夹),本次实验的所有程序和数据都要求存储到本文件夹中(以后实验都按照本次要求)。

2.编写一个输入某个学生10门课程成绩的函数(10门课程成绩放到结构体数组中,结构体包括:课程编号,课程名称,课程成绩)。 3.编写一个求10门成绩中最高成绩的函数,输出最高成绩和对应的课程名称,如果有多个最高成绩,则每个最高成绩均输出。 4.编写一个求10门成绩平均成绩的函数。 5.编写函数求出比平均成绩高的所有课程及成绩。 #include #include struct subject { int subject_id; char subject_name[20]; double subject_grades; }; struct subject sub[10]; void input() { int i; printf("please input:\n"); for(i=0;i<10;i++) { scanf("%d %s %lf",&sub[i].subject_id,&sub[i].subject_name,&sub[i].subject_g rades); } printf("you just input:\n"); for(i=0;i<3;i++) { printf("%d %s %lf\n",sub[i].subject_id,sub[i].subject_name,sub[i].subject_g rades); } } void subject_max() { int i,flag; double max=sub[0].subject_grades; for(i=0;i<10;i++) { if(sub[i].subject_grades>max)

数据结构实验报告全集

数据结构实验报告全集 实验一线性表基本操作和简单程序 1.实验目的 (1)掌握使用Visual C++ 上机调试程序的基本方法; (2)掌握线性表的基本操作:初始化、插入、删除、取数据元素等运算在顺序存储结构和链表存储结构上的程序设计方法。 2.实验要求 (1)认真阅读和掌握和本实验相关的教材内容。 (2)认真阅读和掌握本章相关内容的程序。 (3)上机运行程序。 (4)保存和打印出程序的运行结果,并结合程序进行分析。 (5)按照你对线性表的操作需要,重新改写主程序并运行,打印出文件清单和运行结果 实验代码: 1)头文件模块 #include >验目的 掌握顺序栈的基本操作:初始化栈、判栈空否、入栈、出栈、取栈顶数据元素等运算以及程序实现方法。 2.实验要求 (1)认真阅读和掌握和本实验相关的教材内容。 (2)分析问题的要求,编写和调试完成程序。 (3)保存和打印出程序的运行结果,并分析程序的运行结果。 3.实验内容 利用栈的基本操作实现一个判断算术表达式中包含圆括号、方括号是否正确配对的程序。具体完成如下:

(1)定义栈的顺序存取结构。 (2)分别定义顺序栈的基本操作(初始化栈、判栈空否、入栈、出栈等)。 (3)定义一个函数用来判断算术表达式中包含圆括号、方括号是否正确配对。其中,括号配对共有四种情况:左右括号配对次序不正确;右括号多于左括号;左括号多于右括号;左右括号匹配正确。 (4)设计一个测试主函数进行测试。 (5)对程序的运行结果进行分析。 实验代码: #include < > #define MaxSize 100 typedef struct { ??? int data[MaxSize]; ??? int top; }SqStack; void InitStack(SqStack *st) 验目的 (1)进一步掌握指针变量的用途和程序设计方法。 (2)掌握二叉树的结构特征,以及链式存储结构的特点及程序设计方法。 (3)掌握构造二叉树的基本方法。 (4)掌握二叉树遍历算法的设计方法。 3.实验要求 (1)认真阅读和掌握和本实验相关的教材内容。 (2)掌握一个实际二叉树的创建方法。 (3)掌握二叉链存储结构下二叉树操作的设计方法和遍历操作设计方法。 4.实验内容 (1)定义二叉链存储结构。

数据结构实验指导书2014(1)

《数据结构》实验指导书 专业:____________班级:_______________组序:_____________ 学号:______________姓名:_______________ 中国矿业大学管理学院 2014 年9 月

上篇程序设计基础 实验一 Java编程环境 【实验目的】 1.掌握下载Java sdk软件包、Eclipse软件的安装和使用方法 2.掌握设置Java程序运行环境的方法 3.掌握编写与运行Java程序的方法 4.了解Java语言的概貌 【实验内容】 一 JDK下载与安装 1. 下载JDK 为了建立基于SDK的Java运行环境,需要先下载免费SDK软件包。SDK包含了一整套开发工具,其中包含对编程最有用的是Java编译器、Applet查看器和Java解释器。下载链接 https://www.doczj.com/doc/4f5396777.html,。 2.安装SDK 运行下载的JDK软件包,在安装过程中可以设置安装路径及选择组件,默认的组件选择是全部安装,安装成功后,其中bin文件夹中包含编译器(javac.exe)、解释器(java.exe)、Applet查看器(appletviewer.exe)等可执行文件,lib文件夹中包含了所有的类库以便开发Java程序使用,demo文件夹中包含开源代码程序实例。 安装成功后,文件和子目录结构如图1所示。其中bin文件夹中包含编译器(javac.exe)、解释器(java.exe)、Applet查看器(appletviewer.exe)等可执行文件,lib文件夹中包含了所有的类库以便开发Java程序使用,sample文件夹包含开源代码程序实例,src压缩文件中包含类库开源代码。 图1 二.设置环境变量

数据结构实验指导书(C版)

数据结构实验指导书(C语言版) 2017年9月

目录 1、顺序表的实现 (1) 2、链栈的实现 (3) 3、前序遍历二叉树 (5) 4、图的深度优先遍历算法 (7) 5、散列查找 (9)

1、顺序表的实现 1. 实验目的 ⑴掌握线性表的顺序存储结构; ⑵验证顺序表及其基本操作的实现; ⑶理解算法与程序的关系,能够将顺序表算法转换为对应的程序。 2. 实验内容 ⑴建立含有若干个元素的顺序表; ⑵对已建立的顺序表实现插入、删除、查找等基本操作。 3. 实现提示 定义顺序表的数据类型——顺序表结构体SeqList,在SeqList基础上实现题目要求的插入、删除、查找等基本操作,为便于查看操作结果,设计一个输出函数依次输出顺序表的元素。简单起见,本实验假定线性表的数据元素为int型,要求学生: (1)将实验程序调试通过后,用模板类改写; (2)加入求线性表的长度等基本操作; (3)重新给定测试数据,验证抛出异常机制。 4. 实验程序 在编程环境下新建一个工程“顺序表验证实验”,并新建相应文件,文件包括顺序表结构体SeqList的定义,范例程序如下: #define MaxSize 100 /*假设顺序表最多存放100个元素*/ typedef int DataType; /*定义线性表的数据类型,假设为int型*/ typedef struct { DataType data[MaxSize]; /*存放数据元素的数组*/ int length; /*线性表的长度*/ } SeqList; 文件包括建立顺序表、遍历顺序表、按值查找、插入操作、删除操作成员函数的定义,范例程序如下: int CreatList(SeqList *L, DataType a[ ], int n) { if (n > MaxSize) {printf("顺序表的空间不够,无法建立顺序表\n"); return 0;} for (int i = 0; i < n; i++) L->data[i] = a[i]; L->length = n; return 1; }

水工结构静力模型实验指导书

水工结构静力模型实验指导书 河海大学 一、课程性质和目的: (1)水工结构模型试验 所谓水工结构模型试验就是将原型以某一比例关系缩小成模型,然后向该模型施加与原型相关的荷载,根据从模型上获得的信息如应变位移等,通过一定的相似关系推出原型建筑物在应力、变形强度等成果。 (2)进行水工结构模型试验的目的和意义 水工建筑物因其受力特征、几何形状、边界条件等均较复杂,特别是修建在复杂地基上建筑物更为如此,尽管计算机技术和空间有限元等正迅速发展,但目前还不能用理论分析方法完美地解决建筑物的稳定和应力问题,因此模型试验作为一种研究手段则具有重要的意义,可归纳成如几个方面: 1.通过对水工建筑物的模型试验研究可以验证理论设计,国内外大型和重要的水工建筑物的设计,都同时要求进行计算分析和试验分析,以期达到互相验证的目的。 2.通过对原型结构的模拟试验,预测水工建筑物完建后的运行情况以及抵御事故的能力。 3.由于物理模型是对实际结构性态的模拟,在模型上还有可能出现原先未知而又实际存在的某些现象,因此模型试验研究不仅仅是对数理分析方法的验证,而且是获得更丰富切合实际的资料的积极探索,所以进行水工结构模型试验目的也是更好地探索新理论、新材料、新技术、新工艺的一种手段。 (3)结构模型试验研究的主要内容: a.大型水工建筑物的整体应力及变形问题。 b.结构物之间的联合作用问题。 c.地下结构的应力与稳定问题。 d.大坝安全度及破坏机理问题。 e.水工结构的动力特性问题。 f.验证新理论、新方法、新材料、新工艺等。 (4)模型试验的分类方法 ①按建筑物的模拟范围和受力状态分类 a.整体结构模型试验:研究整体建筑物在空间力系作用下的强度或稳定问题。 b.平面结构模型试验:研究结构单位长度断面在平面力系作用下的强度和稳定问题,如重力坝坝段平面结构模型试验就是研究重力坝在水荷载作用下的应力和变形。 c.半整体结构模型试验: ②按作用荷载特性分类 a.静力结构模型试验:研究水工建筑物在静荷载(静水压力、自重、温度等)作用下

数据结构上机实验线性表单链表源代码

#include template class LinearList { public: virtual bool IsEmpty()const=0; virtual int Length()const=0; virtual bool Find(int i,T& x)const=0; virtual int Search(T x)const=0; virtual bool Insert(int i,T x)=0; virtual bool Update(int i,T x)=0; virtual bool Delete(int i)=0; virtual void Output(ostream& out)const=0; protected: int n; }; #include "linearlist" template class SeqList:public LinearLisr { public: SeqList(int mSize); ~SeqList(){delete [] elements;} bool IsEmpty()const; bool Find(int i,T& x)const; int Length()const; int Search(T x)const; bool Insert(int i,T x); bool Update(int i,T x); bool Delete(int i); void Output(ostream& out)const; private: int maxLength; T *elements; }; template SeqList::SeqList(int mSize) { maxLength=mSize;

混凝土结构实验指导书及实验报告(学生用)

土木工程学院 《混凝土结构设计基本原理》实验指导书 及实验报告 适用专业:土木工程周淼 编 班级::学 号: 理工大学 2018 年9 月

实验一钢筋混凝土梁受弯性能试验 一、实验目的 1.了解适筋梁的受力过程和破坏特征; 2.验证钢筋混凝土受弯构件正截面强度理论和计算公式; 3.掌握钢筋混凝土受弯构件的实验方法及荷载、应变、挠度、裂缝宽度等数据的测试技术 和有关仪器的使用方法; 4.培养学生对钢筋混凝土基本构件的初步实验分析能力。 二、基本原理当梁中纵向受力钢筋的配筋率适中时,梁正截面受弯破坏过程表现为典型的三个阶段:第一阶段——弹性阶段(I阶段):当荷载较小时,混凝土梁如同两种弹性材料组成的组合梁,梁截面的应力呈线性分布,卸载后几乎无残余变形。当梁受拉区混凝土的最大拉应力达到混凝土的抗拉强度,且最大的混凝土拉应变超过混凝土的极限受拉应变时,在纯弯段某一薄弱截面出现首条垂直裂缝。梁开裂标志着第一阶段的结束。此时,梁纯弯段截面承担的弯矩M cr称为开裂弯矩。第二阶段——带裂缝工作阶段(II阶段):梁开裂后,裂缝处混凝土退出工作,钢筋应力急增,且通过粘结力向未开裂的混凝土传递拉应力,使得梁中继续出现拉裂缝。压区混凝土中压应力也由线性分布转化为非线性分布。当受拉钢筋屈服时标志着第二阶段的结束。此时梁纯弯段截面承担的弯矩M y称为屈服弯矩。第三阶段——破坏阶段(III阶段):钢筋屈服后,在很小的荷载增量下,梁会产生很大的变形。裂缝的高度和宽度进一步发展,中和轴不断上移,压区混凝土应力分布曲线渐趋丰满。当受压区混凝土的最大压应变达到混凝土的极限压应变时,压区混凝土压碎,梁正截面受弯破坏。此时,梁承担的弯矩M u 称为极限弯矩。适筋梁的破坏始于纵筋屈服,终于混凝土压碎。整个过程要经历相当大的变形,破坏前有明显的预兆。这种破坏称为适筋破坏,属于延性破坏。 三、试验装置

(完整版)汽车构造实验指导书(精)

汽车构造实验指导书 李国政编 青岛大学机电工程学院车辆工程系 2006年2月

前言 汽车整车拆装实训课是汽车专业的重要实践环节,它与课堂讲授课密切配合,共同完成教学大纲规定的教学任务。通过实训课,使同学们建立汽车整车构造的实物概念,进一步巩固课堂讲授的知识,更深入的了解汽车各总成部件构造细节及名称,熟悉汽车部件的拆装及操作工艺,为后继专业课程及专业性实习打下基础。 实训课的目的是配合课堂教学、结合实物系统的分解观察掌握汽车主要零部件的功能、组成、结构、类型和工作原理。 实训课的教学内容包括实物讲授和拆装观察分析两部分。 实物讲授是由于有些内容受条件限制,在课堂上难以讲清,故安排在实验课中结合实物进行讲授。 拆装观察是对完整的实物或重要总成分解成零件,然后分析观察零件的形状,安装定位基准,各部件的关系,调整方法和装配工艺,培养学生的实际动手能力和思考分析能力。 为使实训课顺利进行,对学生提出以下要求: 1.实训前要全面复习课堂讲授的有关内容,记住其主要内容。 2.实训中听从教师指导、严格遵守实验室各项规章制度,注意安全。 3.爱护实训教具及设备,与实验课无关的设备不要乱动。 4.在实训中要认真观察分析各零部件,要勤学多问,总结实训收获,认真完成实训报告。 实训地点:车辆实验室

实训一汽车及发动机的总体构造 一、目的 1.通过实训对汽车的组成、总布置型式以及各总成有一个初步认识; 2.了解各组成部分的基本功用及在结构上的相互联系; 3.初步了解不同类型的汽车的结构特征。 二、基础知识 1.汽车总体构造 汽车由许多不同的装置和部件组成,其结构型式和安装位置多种多样。汽车所用的动力装置不同时,其总体构造差异很大。汽车主要由发动机、底盘、车身和电气设备等四部分组成。小轿车还装有空调和其他附属设备。 (1)发动机 使供入其中的燃油燃烧产生动力,是汽车行驶的动力源泉。 (2)底盘 接受发动机的动力,使汽车正常行驶。由传动系、行驶系、转向系和制动系组成。 行驶系—安装部件、支承全车并保证行驶。由车架、车桥、车轮和悬架等组成。 转向系—保证汽车按驾驶员选定的方向行驶。由转向器和转向传动机构组成。 制动系—使汽车能减速行驶以至停车,并保证汽车能可靠停驻。 (3)车身 用以安置驾驶员、乘客或货物。客车和轿车是整体车身;普通货车 车身由驾驶室和货箱组成。 (4) 电气设备 由电源和用电设备组成,包括发电机、蓄电池、起动系、点火系以及汽车的照明、信号装置和仪表等。此外,在现代汽车上愈来愈多装用的各种电子设备:微处理机、中央计算机系统及各种人工智能装置(自诊、防盗、巡航、防抱死、车身高度自调等),显著地提高了汽车的使用性能。 三、实训内容 1.长安6331A型微型客车及日本五十铃的总体结构。 2.北内109发动机、天津夏利轿车发动机及日本皇冠3.0发动机的总体构造。 3.CA1091及桑塔纳汽车模型及部件模型的观察。 四、实训报告 汽车的布置型式通常有几种,各有何优点?实验中各车采取何种布置型式?试述原因。

相关主题
文本预览
相关文档 最新文档