实验任务书1Word文件下载.docx
- 文档编号:7970756
- 上传时间:2023-05-09
- 格式:DOCX
- 页数:15
- 大小:46.27KB
实验任务书1Word文件下载.docx
《实验任务书1Word文件下载.docx》由会员分享,可在线阅读,更多相关《实验任务书1Word文件下载.docx(15页珍藏版)》请在冰点文库上搜索。
可以贴相应的运行结果截图。
5、算法分析与改进:
算法的时间复杂度和空间复杂度分析;
算法改进的设想。
6、经验和体会
所有实验做完后,上交上机实验源程序和相应的运行结果截图。
源程序要加注释。
如果题目规定了测试数据,则截图结果要包含这些测试数据和运行输出,当然还可以含有其它测试数据和运行输出(有时需要多组数据)。
三、实验学时
16学时
实验1线性表的顺序存储结构
实验目的
1.熟悉C语言的上机环境,掌握使用VC环境上机调试线性表的基本方法;
2.掌握线性表的顺序存储结构及其线性表的基本操作:
插入、删除、查找等。
3.掌握线性表合并等运算在顺序存储结构上的实现。
实验要求
1.认真阅读和掌握本实验的程序。
2.上机运行程序,观察程序的运行结果。
3.按照你对线性表的操作需要,重新改写主程序并运行。
实验内容(基础题必做,应用题、提高题可选)
1.基础题:
线性表基本操作的实现
这个程序中演示了顺序表的创建、插入、删除和查找,
(1)请修改并记录运行结果;
(2)按照你自己对线性表测试的需要,增加新的操作,重新改写主程序并记录运行结果。
#include<
stdio.h>
stdlib.h>
//顺序表的定义
#defineListSize100
typedefintElemType;
typedefstruct
{ElemType*elem;
/*存放表元素的空间基地址*/
intlength;
/*当前的表长度*/
intlistsize;
/*能容纳的最大元素个数*/
}SeqList;
voidCreateList(SeqList&
L,intn);
voidPrintList(SeqListL,intn);
intLocateList(SeqListL,intx);
voidInsertList(SeqList&
L,intx,inti);
voidDeleteList(SeqList&
L,inti);
voidmain()
{
SeqListL;
inti,x;
intn=10;
/*THELENGTHOFLIST*/
L.length=0;
clrscr();
CreateList(L,n);
/*CREATETHELIST*/
PrintList(L,n);
/*PRINTTHELIST*/
printf("
INPUTTHESEARCHELEMENT"
);
scanf("
%d"
&
x);
i=LocateList(L,x);
thesearchpositionis%d\n"
i);
/*顺序表查找*/
inputthepositionofinsert:
\n"
i);
inputthevalueofinsert\n"
InsertList(L,x,i);
/*顺序表插入*/
/*打印顺序表*/
inputthepositionofdelete\n"
DeleteList(L,i);
/*顺序表删除*/
getch();
/*打印顺序表*/
}
/*顺序表的建立:
*/
L,intn)
{
L.elem=(ElemType*)malloc(ListSize*sizeof(ElemType));
if(!
L.elem)exit(0);
L.listsize=ListSize;
inti;
printf("
pleaseinputnnumbers\n"
for(i=1;
i<
=n;
i++)
scanf("
L.elem[i]);
L.length=n;
/*顺序表的打印:
voidPrintList(SeqListL,intn)
{inti;
thesqlistis\n"
%d"
L.elem[i]);
/*顺序表的查找:
intLocateList(SeqListL,intx)
=10;
if((L.elem[i])==x)return(i);
elsereturn(0);
/*顺序表的插入:
L,intx,inti)
{intj;
for(j=L->
length;
j>
=i;
j--)
L->
elem[j+1]=L->
elem[j];
elem[i]=x;
L.length++;
/*顺序表的删除:
L,inti)
{intj;
for(j=i;
j<
=(L.length)-1;
j++)
L.elem[j]=L.elem[j+1];
2.应用题
(1)求集合A、B的并集C。
(2)归并两个有序表La和Lb成一个新的有序表Lc。
有序指值非递减。
3.提高题
(1)学生成绩管理
本题目是对学生成绩管理的简单模拟,用菜单选择方式完成下列功能:
输入学生数据;
输出学生数据;
学生数据查询;
添加学生数据;
修改学生数据;
删除学生数据。
本题目的数据是一组学生的成绩信息,每条学生的成绩信息由学号、姓名和成绩组成。
(2)考试报名管理
本项目是对考试报名管理的简单模拟,用菜单选择方式完成下列功能:
输入考生信息;
输出考生信息;
查询考生信息;
添加考生信息;
修改考生信息;
删除考生信息。
本题目的数据是一组考生信息,每条考生信息由准考证号、姓名、性别、年龄、报考类别等信息组成。
实验2链表的应用
1.定义单链表的结点类型。
2.熟悉对单链表的一些基本操作和具体的函数定义。
3.通过单链表的定义掌握线性表的链式存储结构的特点。
4.熟悉单链表的应用场合。
1.独立完成;
2.准备好测试数据,程序调试正确,有执行结果。
实验内容(基础题必做,应用题、提高题任选)
1.基础题:
按照教材中抽象数据类型线性表的定义,演示单链表的基本操作,按照自己的意图编写基本操作函数和主函数进行测试。
示例:
这个程序演示了单链表的创建和插入操作。
程序如下:
#include<
typedefstructnode{
ElemTypedata;
structnode*next;
}NODE;
typedefNODE*LinkList;
/******************************************/
LinkListCreate(){
NODE*p,*head;
intx;
head=(NODE*)malloc(sizeof(NODE));
head->
next=NULL;
Inputdata,-1toEnd!
while(x!
=-1){
p=(NODE*)malloc(sizeof(NODE));
p->
data=x;
next=head->
next;
next=p;
}
return(head);
voidOutput(LinkListhead){
NODE*p;
p=head;
BegintodumptheLinkList...\n"
while(p->
next!
=NULL){
->
p->
next->
data);
p=p->
\nTheLinkListended!
intListlen(LinkListhead){
inti=0;
NODE*p=head;
i++;
return(i);
voidIns(LinkListhead,inti,inte){
NODE*p=head,*q;
intj=0;
while(p->
next&
&
i-1){
j++;
p=p->
p->
i-1)printf("
Wrongposition\n"
);
else{
q=(NODE*)malloc(sizeof(NODE));
q->
data=e;
next=p->
next=q;
main(){
LinkListhead;
inti,element;
head=Create();
Output(head);
length=Listlen(head);
thelengthofthelinkis%d\n"
length);
Inputtheinsertpositionandelement:
%d%d"
i,&
element);
Ins(head,i,element);
}
(1)约瑟夫生者死者游戏:
30个旅客同乘一条船,因为严重超载,加上风高浪大,危险万分;
因此船长告诉乘客,只有将全船一半的旅客投入海中,其余人才能幸免遇难。
无奈,大家只得同意这种办法,并议定30个人围成一圈,由第一个人开始,依次报数,数到第9人,便把他投入大海中,然后从他的下一个人数起,数到第9人,再将他投入大海,如此循环,直到剩下15个乘客为止。
问哪些位置是将被扔下大海的位置。
本游戏的数学建模如下:
假设n个旅客排成一个环形,依次顺序编号1,2,…,n。
从某个指定的第1号开始,沿环计数,每数到第m个人就让其出列,且从下一个人开始重新计数,继续进行下去。
这个过程一直进行到剩下k个旅客为止。
本游戏要求用户输入的内容包括:
1)旅客的个数,也就是n的值;
2)离开旅客的间隔数,也就是m的值;
3)所有旅客的序号作为一组数据要求存放在某种数据结构中。
本游戏要求输出的内容包括
1)离开旅客的序号;
2)剩余旅客的序号。
(2)一元多项式求和
有两个指数递减的一元多项式,写一程序求这两个多项式的和。
提示:
用带表头结点的单链表作为多项式的存储表示;
要建立两个单链表;
多项式相加就是要把一个单链表中的结点插入到另一个单链表中去,要注意插入、删除操作中指针的正确修改。
实验3栈的应用
1.会定义顺序栈和链栈的类型。
2.掌握栈的插入和删除在操作上的特点。
3.熟悉对栈的一些基本操作和具体的函数定义。
2.程序调试正确,有执行结果。
按照教材中抽象数据类型栈的定义,采用顺序存储结构(用动态数组)或链式存储结构,编写主函数演示顺序栈/链栈的基本操作。
2.应用题:
(1)判断给定的字符串是否中心对称。
(2)数制转换
(3)表达式括号匹配问题
3.提高题
(1)算符优先算法为表达式求值
(2)迷宫求解
实验4队列的应用
1.掌握队列的存储结构及基本操作。
2.掌握循环队列的设置及循环队列的各种基本操作的实现。
3.通过具体的应用实例,进一步熟悉和掌握队列的实际应用。
实验内容(基础题必做,应用题任选)
1、基础题:
按照教材中抽象数据类型队列的定义,采用顺序存储结构(循环队列)或链式存储结构,编写主函数演示循环队列/链队列的基本操作。
2、应用题:
舞伴问题:
假设在周末舞会上,男士们和女士们进入舞厅时,各自排成一队,跳舞开始时,依次从男队和女队的队头上各出一人配成舞伴,若两队初始人数不相同,则较长的那一队中未配对者等待下一轮舞曲。
设计一个函数partner(),模拟上述舞伴配对问题。
基本要求:
1)由键盘输入数据,每对数据包括姓名和性别;
2)输出结果包括配成舞伴的女士和男士的姓名,以及未配对者的队伍名称和队头者的姓名;
实验5树的应用
1.熟悉二叉树结点的结构和对二叉树的基本操作。
2.掌握对二叉树每一种操作的具体实现。
3.学会利用递归方法编写对二叉树这种递归数据结构进行处理的算法。
4.在二叉树基本操作的基础上掌握对二叉树的一些其它操作的具体实现方法。
5.掌握构造哈夫曼树以及哈夫曼编码的方法。
按照教材中抽象数据类型二叉树的定义,采用二叉链表存储结构,编写主函数演示二叉树的基本操作(不少于5个),如:
(1)StatusInitBTree(BiTree&
BT)//初始化二叉树BT
(2)StatusCreateBTree(BiTree&
BT,char*a)
//根据先序序列a建立二叉链表存储结构
(3)StatusEmptyBTree(BiTreeBT)
//检查二叉树BT是否为空,空返回Yes,否则返回No
(4)intDepthBTree(BiTreeBT)//求二叉树BT的深度并返回该值
(5)StatusFindBTree(BiTreeBT,TElemTypex)
//查找二叉树BT中值为x的结点,若查找成功返回该结点地址,否则返回Error
(6)voidPreOrder(BiTreeBT)//先序遍历二叉树BT
(7)voidInOrder(BiTreeBT)//中序遍历二叉树BT
(8)voidPostOrder(BiTreeBT)//后序遍历二叉树BT
(9)voidLevelOrder(BiTreeBT)//按层次遍历二叉树BT
(10)voidPrintBTree(BiTreeBT)//输出二叉树BT
2.应用题
家谱管理:
本题目对家谱管理进行简单的模拟,以实现查看祖先和子孙个人信息、插入家族成员、删除家族成员等功能。
实验6图的应用
1.掌握图的各种存储结构,特别要熟练掌握邻接矩阵和邻接表存储结构。
2.遍历是图各种应用的算法的基础,要熟练掌握图的深度优先遍历和广度优先遍历算法,复习栈和队列的应用。
实验内容
1、基础题(至少做一个)
(1)图的邻接矩阵定义及实现:
定义图的邻接矩阵存储结构,并编写图的初始化、建立图、深度优先/广度优先输出图、输出图的每个顶点的度等基本操作实现函数。
以下图为例,建立一个验证操作实现的主函数进行测试。
(2)图的邻接表的定义及实现:
定义图的邻接表存储结构,并编写图的初始化、建立图、深度优先/广度优先输出图、输出图的每个顶点的度等基本操作实现函数。
同时在主函数中调用这些函数进行验证(以下图为例)。
实验7图的应用
1.掌握图的最短路径概念。
2.掌握生成最小生成树的Prim算法(用邻接矩阵表示图)/克鲁斯卡尔算法。
3.理解求最短路径的DijKstra算法(用邻接矩阵表示图)。
1、基础题
编写用邻接矩阵表示有向带权图时图的基本操作的实现函数,主要包括:
1初始化邻接矩阵表示的有向带权图
2建立邻接矩阵表示的有向带权图(即通过输入图的每条边建立图的邻接矩阵)
3出邻接矩阵表示的有向带权图(即输出图的每条边)。
4编写求最短路径的DijKstra算法函数voidDijkstra(adjmatrixGA,intdist[],edgenode*path[],inti,intn),该算法求从顶点i到其余顶点的最短路径与最短路径长度,并分别存于数组path和dist中。
(可选)
5编写打印输出从源点到每个顶点的最短路径及长度的函数voidPrintPath(intdist[],edgenode*path[],intn)。
同时建立一个验证操作实现的主函数进行测试。
2、应用题
编写Prim算法函数voidPrim(adjmatrixG,edgsetCT,intn)或者克鲁斯卡尔算法函数以及输出边集数组的函数voidPrintEdge(edgesetCT,intn)。
编写主函数测试生成最小生成树并输出(即输出边集)。
测试数据如下:
实验8查找与排序
1.熟悉并掌握各种查找算法
2.掌握排序的基本概念。
3.熟悉各种内部排序的方法。
1.基础题
实现教材中的查找和排序算法(各不少于2种)。
编写主函数以菜单形式测试各个查找和排序算法。
编写程序,完成以下任务:
a)通过键盘输入n个学生的考试成绩表(设计为一个线性表),表中每个元素由学号、姓名与分数组成;
b)按分数高低次序,打印出每个学生在考试中获得的名次,分数相同的为同一名次;
c)按学号查找某个学生成绩信息;
d)按名次打印出每个学生的姓名与分数。
要求:
利用基础题中实现的排序和查找算法,在主函数中首先输入数据,然后调用查找函数查找某个给定的学号的学生成绩,然后调用排序函数排序,并按分数高低次序打印名次与成绩表。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 实验 任务书