数据结构实验指导书

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

实验一顺序表操作实验二栈和队列

实验三栈

实验四二叉树的操作实验五图的遍历操作实验六数据查找

实验七哈希表设计

实验八排序

实验一顺序表操作

一、实验目的

1.熟悉C语言的上机环境,掌握C语言的基本结构。

2.会定义线性表的顺序存储结构。

3.熟悉对顺序表的一些基本操作和具体的函数定义。

二、实验要求

1.认真阅读和掌握本实验内容所给的全部程序。

2.保存和打印出程序运行结果,并结合程序进行分析。

注意事项

在做第一次“数据结构”课程实验之前,要在硬盘(e:\)上建立好自己的工作目录,专门来存储你所做的实验程序及相关信息,以后每次做实验都采用这个目录。

三、实验内容

a.以输入整形数据为主,输入后按“?”结束输入。

b.程序所能表达到的功能为:实现顺序表的创建、查找、插入、删除等功能。

c.程序运行后,输入数据并执行。

#include "stdio.h"

#include "conio.h"

#define MaxSize 50

typedef char elemtype;

typedef struct node

{

elemtype data[MaxSize];

int len;

}lnode,*List;

void init(List L)//创建链表

{ L->len=0;}

int length(List L)//获得链表长度

{ return L->len;}

elemtype getnode(List L,int pos)//返回指定元素

{

if(pos<1 || pos>L->len) printf("error");

else return L->data[pos-1];

}

int locate(List L,elemtype x)//返回所找元素位置

{ int i=0;

while(ilen && L->data[i]!=x) i++;

if(i==L->len) return -1;

else return(i+1);

}

void insert(List L,int pos,elemtype x)//在指定位置插入元素

{ int j;

if(pos<1 || pos>L->len+1) printf("insert error\n");

else {

L->len++;

for(j=L->len;j>=pos;j--) L->data[j]=L->data[j-1];

L->data[pos-1]=x; };

}

void delnode(List L,int pos)//删除指定位置元素

{ int j;

if(pos<1 ||pos>L->len)printf("del error\n");

else {

for(j=pos;jlen;j++)

L->data[j-1]=L->data[j];

L->len--;}

}

void print(List L)//打印元素

{ int i;

for(i=1;ilen;i++)

printf("%c->",L->data[i-1]);

printf("%c",L->data[L->len-1]);

}

main()

{

int i=1,n;

lnode L;

char ch,x;

init(&L);

printf("\n\n\n*******************************顺序表演示程序***********\n"); printf("请输入你想建立的顺序表的元素,以?结束:");

ch=getchar();

while(ch!='?')

{insert(&L,i,ch);

i++;

ch=getchar();

};

printf("你建立的顺序表为:");

print(&L);

printf("\n顺序表的长度为:%d",L.len);

printf("\n输入你想查找的元素:");

fflush(stdin);

scanf("%c",&x);

printf("你查找的元素为%c序位为%d",x,locate(&L,x));

printf("\n输入你想查找的元素序位:");

scanf("%d",&n);

printf("\n你查找的元素为:%c",getnode(&L,n));

printf("\n输入你想插入的元素以及序位:<用逗号隔开>");

fflush(stdin);

scanf("%c,%d",&x,&n);

insert(&L,n,x);

printf("\n插入后顺序表为:");

print(&L);

fflush(stdin);

printf("\n请输入你想删除的元素序位:");

scanf("%d",&n);

delnode(&L,n);

printf("\n删除后的顺序表为:");

print(&L);

getch();

}

四、测试结果

运行程序,屏幕显示:“请输入你想建立的顺序表的元素,以?结束:”输入:54381

你建立的顺序表为:5—>4—>3—>8—>1

顺序表的长度为:5

输入你想查找的元素:4

你查找的元素为4序位为2

输入你想查找的元素序位:4

你查找的元素为:8

输入你想插入的元素以及序位:<用逗号隔开>":6,3

插入后顺序表为:5—>4—>6—>3—>8—>1

请输入你想删除的元素序位:5

删除后的顺序表为:5—>4—>6—>3—>1

实验二栈和队列

一、实验目的:

1、掌握队列和栈的顺序存储结构和链式结构,以便在实际背景下灵活运

用。

2、掌握栈和队列的特点,即先进后出与先进先出的原则。

二、实验内容:停车场管理

[问题描述]

设有一个可以停放N辆汽车的狭长停车场,它只有一个大门利用供车辆进出,车辆按到达停车场时间早晚依次可以从停车场最里面向大门处停

放(最先到达的第一辆放在停车场最里面)。然后停车场已放满N辆车,则

后来的车辆只能停在车场大门外的便道上等待,一旦停车场有车开走,在

它之后进入停车场的车必须先退出停车场为它让路,待其开出停车场后,

这些车辆再依原来的次序进场。每辆车在离开停车场时,都应依据它在停

车场内停留的时间长短交费。如果停留在便道上的未能进停车场就离去,

允许它走,不收停车费,而且仍然保持在便道上的等待的车辆的次序。编

制一程序模拟停车场的管理。

[实现要求]

要求程序输出每辆车到达后的停车位置(停车场或便道上),以及某辆车离开停车场时应交的费用和它在停车场内停留时间;

[实现提示]

汽车的模拟输入信息格式可以是:(到达/离去,汽车牌照号码,到达/离去的时刻)。例如,(A,1,5)表示1号牌照车在5这个时刻到达,而(D,

5,20)表示5号车在20这个时刻离去,整个程序可以在输入信息为(E,

0,0)时结束。本题可用栈和队列来实现。

[程序实现]

(1)设计思想

根据题目要求,停车场只有一个大门,因此可用一个栈来模拟;而当栈满后,继续来的车辆只能停在便道上,根据便道停车的特点,可知这可

以用一个队列来模拟,安排队的车辆先离开便道,进入停车场。由于在停

车场中间的车辆可以提出离开停车场,而且要求在离开车辆到停车场大门

之间的车辆都必须先离开停车场,让此车离去,然后再让这些车辆依原来

的次序进入停车场,因此在一个栈和一个队列的基础上,还需要有一个地

方保存为了让路离开停车场的车辆,很显然这也应该用一个栈来模拟。因

此本题中用到两个栈和一个队列。

对于停车场和车辆规避所,有车辆进入和车辆离去两个动作,这就是栈的进栈和出栈操作,只是还允许排在中间的车辆先离开停车场,因此

在栈中需要进行查找。而对于便道,也有入队列和出队列的操作,同样允

许排在中间的车辆先离去队列。这样基本动作只需利用栈和队列的基本操

作就可实现。

三、详细设计:

#include "stdio.h"

#define N 5 /*定义停车场长度*/

#define M 10

typedef struct /*定义栈元素的类型*/

{int num;

int arrtime;

}elemtype;

typedef struct /*定义栈*/

{elemtype stack[N];

int top;

}stack;

typedef struct node /*定义队列节点类型*/

{int num;

struct node*next;

}queneptr;

typedef struct /*定义队列*/

{queneptr*front,*rear;

}quene;

void initstack(stack*s) /*初始化栈*/

{s->top=-1;

}

int push(stack *s,elemtype x) /*数据元素X进入指针S所指的栈*/

{if(s->top==N-1)

return(0);

else{s->stack[++s->top]=x;

return(1);

}

}

elemtype pop(stack *s)

{elemtype x;

if(s->top<0)

{x.num=0;

x.arrtime=0;

return(x); /*如果栈不空,返回栈顶元素*/

}

else{x=s->stack[s->top];

s->top--;

return x;

}

}

void initquene(quene*s) /*初始化队列*/

{s->front=(queneptr*)malloc(sizeof(queneptr)); /*产生一个新结点,作为

头结点*/

s->rear=s->front;

s->front->next=NULL;

s->front->num=0; /*头结点的NUM保存队列元素的个数*/ }

void enquene(quene *s,int num) /*数据入队列*/

{queneptr *p;

p=(queneptr*)malloc(sizeof(queneptr));

p->num=num;

p->next=NULL;

s->rear->next=p;

s->rear=p;

s->front->num++;

}

int delquene(quene*s)

{queneptr*p;

int n;

if (s->front==s->rear)

return(0); /*如果队列空*/

else{p=s->front->next;

s->front->next=p->next;

if (p->next==NULL)

s->rear=s->front;

n=p->num;

free(p);

s->front->num--;

return(n);

}

}

void arrive(stack*s1,quene*p,elemtype x)

{int f;

f=push(s1,x); /*新到达的车辆入停车栈*/

if (f==0)

{enquene(p,x.num); /*如果停车场满,就进入队列*/

printf("the %d car stops the %d seat of the quene\n",x.num,p->front->num);

}

else printf("the %d car stops the %d seat of the stack\n",x.num,s1->top+1);

}

void leave(stack *s1,stack *s2,quene*p,elemtype x) /*处理车辆离去函数*/

{int n,f=0;

elemtype y;queneptr *q;

while((s1->top>-1)&&(!f))

{y=pop(s1);

if(y.num!=x.num)

n=push(s2,y);

else f=1;

}

if(y.num==x.num) /*如果栈顶元素不是要离开的车辆,就将其放入车辆规避所*/

{printf("the money of the %d is %d yuan\n",y.num,(x.arrtime-y.arrtime)*M);

while(s2->top>-1)

{y=pop(s2);

f=push(s1,y);

}

n=delquene(p);

if(n) /*在停车场中找到要离开的车辆*/

{y.num=n;

y.arrtime=x.arrtime;

f=push(s1,y);

printf("the %d car stops the %d seat of the stak\n",y.num,s1->top+1);

}

}

else {while(s2->top>-1) /*车辆规避所不空,将其全放回停车场*/ {y=pop(s2);f=push(s1,y);}

q=p->front;f=0;

while(f==0&&q->next!=NULL)

if(q->next->num!=x.num) /*如果便道上有车辆,将第一辆车放入停车场*/ q=q->next;

else {q->next=q->next->next;

p->front->num--;

if(q->next==NULL)

p->rear=p->front;

printf("the %d car leave the quene\n",x.num);

f=1;

}

if(f==0) /*在便道上没有找到要离开的车辆,输出数据错误*/ printf("error!the stack and the quene have no the%d car\n",x.num); }

}

void main() /*停车场模拟管理程序*/

{char ch;

stack *s1,*s2;

quene*p;

elemtype x;

int i=1;

clrscr();

s1=(stack*)malloc(sizeof(stack));

s2=(stack*)malloc(sizeof(stack));

p=(quene*)malloc(sizeof(quene));

initstack(s1);initstack(s2); /*初始化停车规避所栈*/

initquene(p); /*初始化便道队列*/

while(i)

{

printf("what do you want to do?\n");

printf("input---(Add/Del/Exit):");

scanf("%c",&ch);

switch (ch)

{case'a':printf("input the number:\n");

scanf("%d",&x.num);

printf("input the time:\n");

scanf("%d",&x.arrtime);

arrive(s1,p,x); /*车辆到达*/

break;

case'd':printf("input the number:\n");

scanf("%d",&x.num);

printf("input the time:\n");

scanf("%d",&x.arrtime);

leave(s1,s2,p,x); /*车辆离开*/

break;

case'e':printf("the end!");

i=0;

break;

default:{printf("input error!---please input again:\n");break;} }

ch=getchar();

}

}

四、使用说明:

1、按提示输入车进入停车场的情况

2、按提示输入车离开停车场的情况

3、车离开后计算车进入停车场的时间并得出应收费用。

五、测试结果:

运行程序后,屏幕出现

what do you want to do?

Input ----(add/del/exit)

/*此时停车场为空,a是车进入停车场,d是车离开停车场,e是程

序结束。*/

a

input the number: /*要求输入停车牌号*/

1

input the time: /*要求输入停车时间*/

2

:/*屏幕返回到提示,可以按以上方法输入多个数据*/

what do you want to do ?

input ----(add/del/exit) /*当输入多个数据后,可以设计车离

开*/

d

input the number: /*要求输入要离开车牌号*/

input the time: /*要求输入车离开的时间*/

5

the money of the 1 is 30 yuan /*输出结果,1小时10元计价

收费*/

实验三栈

一、实验目的:

1.熟练掌握栈的结构,以及这种数据结构的特点;

2.能够在两种存储结构上实现栈的基本运算,特别注意栈满和栈空的判断条件及描述方法;

二、实验内容:

计算表达式的值

【问题描述】

计算用运算符后缀法表示的表达式的值。后缀表达式也称逆波兰表达式,比中缀表达式计算起来更方便简单些,中缀表达式要计算就存在着括号的匹配问题,所以在计算表达式值时一般都是先转换成后缀表达式,再用后缀法计算表达式的值。如:表达式(a+b*c)/d-e用后缀法表示应为abc*+d/e-。只考虑四则算术运算,且假设输入的操作数均为1位十进制数(0—9),并且输入的后缀形式表达式不含语法错误。

【数据描述】

#define add 43 /*运算符加号‘+’的ASCII码*/

#define subs 45 /*运算符减号‘-’的ASCII码*/

#define mult 42 /*运算符乘号‘*’的ASCII码*/

#define div 47 /*运算符除号‘/’的ASCII码*/

#define MAXSIZE 100

typedef struct{

{ int stkdata[MAXSIZE];//用数组来表示栈空间,定义长度为MAXSIZE的栈

int top; //栈顶指针

}STKzone;

typedef STKzone *STK;

typedef enum{true=1,false=0} bool;

typedef enum{ok,error} status;

【算法描述】

用流程图表示见图3-4。

【C源程序】

#include

#define add 43 /*运算符加号‘+’的ASCII码*/

#define subs 45 /*运算符减号‘-’的ASCII码*/

#define mult 42 /*运算符乘号‘*’的ASCII码*/

#define div 47 /*运算符除号‘/’的ASCII码*/

#define MAXSIZE 100

typedef struct

{ int stkdata[MAXSIZE];/*用数组来表示栈空间,定义长度为MAXSIZE的堆栈*/

int top; /*栈顶*/

}STKzone;

typedef STKzone *STK;

typedef enum{true=1,false=0} bool;

typedef enum{ok,error} status;

STKzone expSTKzone;

STK expSTK;

STK initSTK(STKzone *stack_zone){

/*执行栈初始化,建栈指针*/

STK p;

p=stack_zone;

p->top=0;

}

status push(int *term,STK pstk){

/*将一结构型数据送入栈中*/

if(pstk->top==MAXSIZE)

return error; /*栈满,进栈失败*/

pstk->stkdata[pstk->top] =*term;

(pstk->top)++;/*栈顶指针移动*/

return ok;

}/*push*/

bool emptySTK(STK pstk){

/*判断栈是否为空栈*/

return(pstk->top==0);

}

status pop(int *pdata, STK pstk){

/*从栈中取出一结构型数据*/

if(emptySTK(pstk))

return error;

(pstk->top)--;/*退栈*/

*pdata =pstk->stkdata[pstk->top];

return ok;

}

void synerror()

{ printf("\n表达式语法错!");

exit();

}

int eval(char tag,int a1,int a2)

{ switch(tag)

{ case add:return(a1+a2);

case subs:return(a1-a2);

case mult:return(a1*a2);

case div:return(a1/a2);

}

}

main()

{ char c;

int opd1,opd2,temp,c1;

expSTK=initSTK(&expSTKzone);

printf("\n后置表达式:");

while((c=getchar())!='\n')

{ if(c== ' ') continue;

if((c>47)&&(c<58)) /*判断是否是0—9的字符*/ { putchar(c);

c1=c-48; /*把输入的字符型数字转换成数字*/

if(push(&c1,expSTK)==error)/*运算分量进栈*/

{ printf("\n表达式太长\n");

exit();}

}

else if((c==add)||(c==subs)||(c==mult)||(c==div))

{ putchar(c);

if(pop(&opd1,expSTK)==error) /*将运算量1出栈*/

synerror();

if(pop(&opd2,expSTK)==error) /*将运算量2出栈*/

synerror();

temp=eval(c,opd2,opd1);/*计算得到结果*/

push(&temp,expSTK);/*将运算结果进栈*/

}

else synerror();/*出现非法字符*/

}/*while*/

if(pop(&opd1,expSTK)==error) synerror();

if(!(emptySTK(expSTK))) synerror();

printf(“=%-3d\n”,opd1);

}/*main_end*/

【测试数据】

输入: 23+↙

输出: =5 (即求2+3的结果)

输入: 145*+3/3-↙

输出: 4 (即求(1+4*5)/3-3的结果)

【说明】

本算法中对后置法表示的表达式求值按如下规则进行:自左向右扫描,每遇到一个`n+1元组(opd1,opd2,…,opdn,opr)(其中opd为操作数,opr为n元运算符),就计算一次opr (opd1,opd2,…,opdn)的值,其结果取代原来表达式中n+1元组的位置,再从表达式开头重复上述过程,直到表达式中不含运算符为止。

【实验题】

1. 1.假设一个算术表达式中包含零对到多对圆括弧,括弧对之间允许嵌套但不允许交

叉,编写一个算法并上机实现:判断输入的表达式是否正确配对。

Status correct(string express);//括弧配对正确,返回ok,否则返回error

2. 2.用栈实现一般表达式(即中缀表达式)到后缀表达式的转换。

实验四二叉树的操作

一、实验目的

理解并熟悉掌握创建二叉树和实现二叉树的三种遍历

二、实验内容

创建二叉树和实现二叉树的三种遍历

a.根据提示输入字符型数据创建二叉树,输入值为所有字符型数据

b.输出为遍历后的每个结点的值的顺序

c.创建二叉树并能实现二叉树的先序、中序、后序遍历

d.如果输入数据为:a b c

输出结果为:a b c

b a c

b c a

程序流程:main()→clrscr()→createtree()→preorder()→inorder()→postorder

三、源程序

#include "stdlib.h" /*引入头文件*/

struct tnode /*定义二叉树存储结构*/

{char data;

struct tnode*lchild;

struct tnode*rchild;

};

struct tnode tree; /*定义二叉树指针*/

void createtree(struct tnode*t) /*创建函数*/

{struct tnode*p=t; /*把二叉树指针给p*/

char check;

if(p->lchild==NULL||p->rchild==NULL) /*判断左右子树是否为空*/

{printf("please enter the data:"); /*输入根结点数据*/

scanf("%c",&(p->data));

getchar();

}

if(p->lchild==NULL)

{printf("%c leftchild is null.Add? y/n\n",p->data); /*左子树空,询问是否创建*/

scanf("%c",&check);

getchar();

if(check=='y')

{struct tnode*q=(struct tnode*)malloc(sizeof(struct tnode)); /*开辟空间*/

q->lchild=NULL;

q->rchild=NULL;

p->lchild=q;

createtree(q);

}

}

if(p->rchild==NULL)

{printf("%c rightchild is NULL.Add? y/n\n",p->data); /*右子树空,询问是否创建*/ scanf("%c",&check);

getchar();

if(check=='y')

{struct tnode*q=(struct tnode*)malloc(sizeof(struct tnode)); /*开辟空间*/

q->lchild=NULL;

q->rchild=NULL;

p->rchild=q; /*连到二叉树上*/

createtree(q);

}

}

}

void preorder(struct tnode*t) /*先序遍历函数*/

{if(t)

{printf("%c ",t->data); /*输出根结点数据*/

preorder(t->lchild);

preorder(t->rchild);

}

}

void inorder(struct tnode*t) /*中序遍历函数*/

{if(t)

{inorder(t->lchild);

printf("%c ",t->data);

inorder(t->rchild);

}

}

void postorder(struct tnode*t) /*后序遍历函数*/

{if(t)

{

postorder(t->lchild);

postorder(t->rchild);

printf("%c ",t->data);

}

}

void main()

{

clrscr(); /*清屏函数*/

tree.lchild=NULL; /*左子树*/

tree.rchild=NULL; /*右子树*/

createtree(&tree); /*创建二叉树*/

preorder(&tree); /*先序遍历*/

printf("\n");

inorder(&tree); /*中序遍历*/

printf("\n");

postorder(&tree); /*后序遍历*/

}

四、使用说明

程序运行:

1、先输入根结点数据,例如:a

2、输入y或n判断是否创建左子树。输入y然后输入左子树数据

3、输入y或n判断是否创建右子树。输入y然后输入右子树数据

4、按回车可查看遍历结果并退出程序。

五、测试结果

运行程序,屏幕提示:

please enter the data:a /*首先输入根结点,为a*/

a leftchild is null.add?y/n /*询问是否输入a结点的左结点*/

y /*输入*/

please enter the data:b /*输入结点a的左结点,为b*/

b leftchild is null.add?y/n /*询问是否输入b结点的左结点*/

n /*不输入*/

b rightchild is null.add?y/n /*询问是否输入b结点的右结点*/

n /*不输入*/

a rightchild is null.add?y/n /*询问是否输入a结点的右结点*/

y /*输入*/

please enter the data:c /*输入结点a的右结点,为c*/

c leftchil

d is null.add?y/n /*询问是否输入c结点的左结点*/

n /*不输入*/

c rightchil

d is null.add?y/n /*询问是否输入c结点的右结点*/

n /*不输入*/

程序退出,显示结果应为:

a b c /*先序*/

b a

c /*中序*/

b c a /*后序*/

实验五图的遍历操作

一、实验目的:

该程序主要完成对图的创建,并实现图的深度优先遍历和广度优先遍历

二、实验内容:

1、所输入的数据要为整形数据

2、输出的形式为:每按一次回车,遍历一个结点

3、能创建最大结点树为30的任意图,实现对无向图的两种遍历

程序流程:

main()→clrscr()→visited()→DFS()→visited()→BFS()

三、源程序:

#include /*引用两个头文件*/

#define maxvex 30 /*定义MAXVEX=30*/

struct edgenode /*定义边的结构体*/

{int adjvex;

char info;

struct edgenode*next;

};

struct vexnode /*定义点的结构体*/

{char data;

struct edgenode*link;

};

typedef struct vexnode adjlist[maxvex]; /*自定义adjlist为结构体数组类型*/

adjlist tu1; /*定义结构体数组变量tu1*/

void creategraph(adjlist g,int n) /*图创建函数*/

{int e,i,s,d; /*定义存储边、点的变量*/

struct edgenode*p,*q; /*定义边的结构体指针*/

printf("the point(n) and edge(e):"); /*显示提示输入点,边*/

scanf("%d,%d",&n,&e); /*接收点、边存入n,e中*/

for(i=1;i<=n;i++)

{getchar();

printf("\tthe %d information:",i); /*提示输入结点信息*/

scanf("%c",&g[i].data); /*存储信息*/

g[i].link=NULL; /*最后指针为空*/

}

for(i=1;i<=e;i++)

{printf("\nthe%d edges=>\n\t :",i); /*提示输入边信息*/

scanf("%d,%d",&s,&d); /*接收边的信息*/

p=(struct edgenode*)malloc(sizeof(struct edgenode));

q=(struct edgenode*)malloc(sizeof(struct edgenode)); /*开辟两个存储边的空间*/ p->adjvex=d; /*把其中一个点存储下来*/

p->info=g[d].data;

q->adjvex=s; /*把另一个点存储下来*/

q->info=g[s].data;

p->next=g[s].link; /*p和s的link指针连接起来*/

g[s].link=p;

q->next=g[d].link; /*q和s的link指针连接起来*/

g[d].link=q; /*完成一个边的创建*/

}

}

int visited[maxvex]; /*定义访问数组*/

void dfs(adjlist adj,int v) /*深度优先遍历函数*/

{int i;

struct edgenode*p; /*定义边指针*/

visited[v]=1; /*把开始遍历的点在访问数组中标识*/ printf("now is at point %d",v); /*输出正访问的点*/

p=adj[v].link;

printf("the data is %c \n",adj[v].data); /*输出点的信息*/

getch();

while(p)

{if(visited[p->adjvex]==0)

dfs(adj,p->adjvex); /*没有访问的再调用DFS函数*/ p=p->next; /*访问过的判断下一个*/

}

}

int quene[maxvex];

void bfs(adjlist adj,int vi) /*广度优先遍历函数*/

{int m=maxvex; /*定义一个队列*/

int front=0,rear=1,v;

struct edgenode*p; /*定义边指针*/

visited[vi]=1; /*开始访问的点标识一下*/

printf("now visit the point:%d\n",vi); /*输出正访问的点*/

getch();quene[rear]=vi; /*把访问过的点放入数组中*/

while(front!=rear)

{front=(front+1)%m;

v=quene[front];

p=adj[v].link;

while(p)

{if(visited[p->adjvex]==0) /*判断p->adjvex点是否访问过*/

{visited[p->adjvex]=1; /*访问没有访问过的结点*/

printf("now visit the point:%d\n",p->adjvex); /*输出正访问的结点*/

getch();

rear=(rear+1)%m;

quene[rear]=p->adjvex; /*放入数组中*/

}

p=p->next; /*指向下一个*/

}

}

}

void main()

{int i;clrscr();

creategraph(tu1,0); /*创建图*/

for(i=1;i

visited[i]=0; /*访问数组初始化*/

dfs(tu1,1); /*调用DFS*/

getch(); /*等待输入*/

for(i=1;i

visited[i]=0;

bfs(tu1,1); /*调用BFS*/

}

四、使用说明:

根据屏幕上的英文提示先输入结点的个数和边数。然后输入各结点存储的信息,再输入定义的边,形成图。最后分别按照DFS深度优先遍历和BFS广度优先遍历实现对图的遍历。

五、测试结果:

运行程序,屏幕提示:

the point(n) and edge(e):4,3 /*输入顶点和边的数目*/

the 1 information:a /*各个顶点的信息*/

the 2 information:b

the 3 information:c

the 4 information:d

the 1 edges=> /*各个边的连接情况*/

:1,2

the 2 edges=>

:1,3

the 3 edges=>

:3,4

now is at point 1 the data is a /*深度优先遍历结果*/

now is at point 3 the data is c

now is at point 4 the data is d

now is at point 2 the data is b

now visit the point:1 /*广度优先遍历结果*/

now visit the point:3 now visit the point:2 now visit the point:4

数据结构课程实验指导书

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

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

数据结构实验报告格式

《数据结构课程实验》大纲 一、《数据结构课程实验》的地位与作用 “数据结构”是计算机专业一门重要的专业技术基础课程,是计算机专业的一门核心的关键性课程。本课程较系统地介绍了软件设计中常用的数据结构以及相应的存储结构和实现算法,介绍了常用的多种查找和排序技术,并做了性能分析和比较,内容非常丰富。本课程的学习将为后续课程的学习以及软件设计水平的提高打下良好的基础。 由于以下原因,使得掌握这门课程具有较大的难度: (1)内容丰富,学习量大,给学习带来困难; (2)贯穿全书的动态链表存储结构和递归技术是学习中的重点也是难点; (3)所用到的技术多,而在此之前的各门课程中所介绍的专业性知识又不多,因而加大了学习难度; (4)隐含在各部分的技术和方法丰富,也是学习的重点和难点。 根据《数据结构课程》课程本身的技术特性,设置《数据结构课程实验》实践环节十分重要。通过实验实践内容的训练,突出构造性思维训练的特征, 目的是提高学生组织数据及编写大型程序的能力。实验学时为18。 二、《数据结构课程实验》的目的和要求 不少学生在解答习题尤其是算法设计题时,觉得无从下手,做起来特别费劲。实验中的内容和教科书的内容是密切相关的,解决题目要求所需的各种技术大多可从教科书中找到,只不过其出现的形式呈多样化,因此需要仔细体会,在反复实践的过程中才能掌握。 为了帮助学生更好地学习本课程,理解和掌握算法设计所需的技术,为整个专业学习打好基础,要求运用所学知识,上机解决一些典型问题,通过分析、设计、编码、调试等各环节的训练,使学生深刻理解、牢固掌握所用到的一些技术。数据结构中稍微复杂一些的算法设计中可能同时要用到多种技术和方法,如算法设计的构思方法,动态链表,算法的编码,递归技术,与特定问题相关的技术等,要求重点掌握线性链表、二叉树和树、图结构、数组结构相关算法的设计。在掌握基本算法的基础上,掌握分析、解决实际问题的能力。 三、《数据结构课程实验》内容 课程实验共18学时,要求完成以下六个题目: 实习一约瑟夫环问题(2学时)

数据结构习题(456章)

第四章串 一.选择题 1.若串S='software',其子串的数目是() A.8 B.37 C.36 D.9 2.设有两个串p和q,求q在p中首次出现的位置的运算称作() A.连接B.模式匹配C.求串长D.求子串 3.设字符串S1=“ABCDEFG”,S2=“PQRST”,则运算: S=CONCAT(SUBSTR(S1,2,LEN(S2));SUBSTR(S1,LEN(S2),2));后的串值为() A.A BCDEF B.BCDEFG C.BCDPQRST D. BCDEFEF 4.下面的说法中,只有()是正确的 A.串是一种特殊的线性表B.串的长度必须大于零 C.串中元素只能是字母D.空串就是空白串 5.两个字符串相等的条件是() A.两串的长度相等 B.两串包含的字符相同 C.两串的长度相等,并且两串包含的字符相同 D.两串的长度相等,并且对应位置上的字符相同 二.填空题 1.串“ababcbaababd”的next函数值为,nextval函数值为。2.子串的长度为。 第五章数组和广义表 一.选择题 1.设有数组A[i,j],数组的每个元素长度为3字节,i的值为1 到8 ,j的值为1 到10,数组从内存首地址BA开始顺序存放,当用以列为主存放时,元素A[5,8]的存储首地址为( ) A. BA+141 B. BA+180 C. BA+222 D. BA+225 2.假设以行序为主序存储二维数组A=array[1..100,1..100],设每个数据元素占2个存储单元,基地址为10,则LOC[5,5]=() A. 808 B. 818 C. 1010 D. 1020 3.对稀疏矩阵进行压缩存储目的是() A.便于进行矩阵运算B.便于输入和输出C.节省存储空间D.降低运算的时间复杂度 4.假设以三元组表表示稀疏矩阵,则与如图所示三元组表对应的4×5的稀疏矩阵是(注:矩阵的行列下标均从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) 附:实验报告模板 .......... 错误!未定义书签。

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

数据结构实验报告代码

线性表 代码一 #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)编程实现二叉排序树,包括生成、插入,删除; 2)对二叉排序树进行先根、中根、和后根非递归遍历; 3)每次对树的修改操作和遍历操作的显示结果都需要在屏幕上用树的形状表示出来。 4)分别用二叉排序树和数组去存储一个班(50人以上)的成员信息(至少包括学号、姓名、成绩3项),对比查找效率,并说明在什么情况下二叉排序树效率高,为什么? 二.解决方案 对于前三个题目要求,我们用一个程序实现代码如下 #include #include #include #include "Stack.h"//栈的头文件,没有用上 typedefintElemType; //数据类型 typedefint Status; //返回值类型 //定义二叉树结构 typedefstructBiTNode{ ElemType data; //数据域 structBiTNode *lChild, *rChild;//左右子树域 }BiTNode, *BiTree; intInsertBST(BiTree&T,int key){//插入二叉树函数 if(T==NULL) { T = (BiTree)malloc(sizeof(BiTNode)); T->data=key; T->lChild=T->rChild=NULL; return 1; } else if(keydata){ InsertBST(T->lChild,key); } else if(key>T->data){ InsertBST(T->rChild,key); } else return 0; } BiTreeCreateBST(int a[],int n){//创建二叉树函数 BiTreebst=NULL; inti=0; while(i

数据结构实验8实验报告

暨南大学本科实验报告专用纸 课程名称数据结构实验成绩评定 实验项目名称习题6.37 6.38 6.39 指导教师孙世良 实验项目编号实验8 实验项目类型实验地点实验楼三楼机房学生姓名林炜哲学号2013053005 学院电气信息学院系专业软件工程 实验时间年月日午~月日午温度℃湿度(一)实验目的 熟悉和理解二叉树的结构特性; 熟悉二叉树的各种存储结构的特点及适用范围; 掌握遍历二叉树的各种操作及其实现方式。 理解二叉树线索化的实质是建立结点与其在相应序列中的前去或后继之间的直接联系,熟练掌握二叉树的线索化的过程以及在中序线索化树上找给定结点的前驱和后继的方法。 (二)实验内容和要求 6.37试利用栈的基本操作写出先序遍历的非递归形式的算法。 6.38同题6.37条件,写出后序遍历的非递归算法(提示:为分辨后序遍 历时两次进栈的不同返回点需在指针进栈时同时将一个标志进栈)。 6.39假设在二叉链表的结点中增设两个域:双亲域以指示其双亲结点; 标志域以区分在遍历过程中到达该结点时应继续向左或向右或访问该节点。试以此存储结构编写不用栈进行后序遍历的递推形式的算法。(三)主要仪器设备 实验环境:Microsoft Visual Studio 2012 (四)源程序

6.37: #include #include #define STACK_INIT_SIZE 100 #define STACKINCREMENT 10 #define TRUE 1 #define FALSE 0 typedef struct bitnode{ char data; struct bitnode *lchild,*rchild; }bitnode,*bitree; void create(bitree &T){ char t; t=getchar(); if(t==' ') T=NULL; else{ if( !( T=(bitnode*)malloc(sizeof(bitnode)) ) ) exit(0); T->data=t; create(T->lchild); create(T->rchild); } } typedef struct{ bitree *base; bitree *top; int stacksize; }sqstack; void initstack(sqstack &S){ S.base=(bitree*)malloc(STACK_INIT_SIZE *sizeof(bitree)); if(!S.base) exit(0); S.top=S.base; S.stacksize=STACK_INIT_SIZE; } void Push(sqstack &s,bitree e){ if(s.top - s.base >= s.stacksize){ s.base =

数据结构实验指导书

《数据结构》实验指导书 实验一顺序表 实验目的: 熟悉顺序表的逻辑特性、存储表示方法和顺序表的基本操作。 实验要求: 了解并熟悉顺序表的逻辑特性、存储表示方法和顺序表的基本操作的实现和应用。 实验内容: 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)为不合法。

数据结构实验一的源代码

#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"); }

数据结构实验报告全集

数据结构实验报告全集 实验一线性表基本操作和简单程序 1.实验目的 (1)掌握使用Visual C++ 6.0上机调试程序的基本方法; (2)掌握线性表的基本操作:初始化、插入、删除、取数据元素等运算在顺序存储结构和链表存储结构上的程序设计方法。 2.实验要求 (1)认真阅读和掌握和本实验相关的教材内容。 (2)认真阅读和掌握本章相关内容的程序。 (3)上机运行程序。 (4)保存和打印出程序的运行结果,并结合程序进行分析。 (5)按照你对线性表的操作需要,重新改写主程序并运行,打印出文件清单和运行结果 实验代码: 1)头文件模块 #include iostream.h>//头文件 #include//库头文件-----动态分配内存空间 typedef int elemtype;//定义数据域的类型 typedef struct linknode//定义结点类型 { elemtype data;//定义数据域 struct linknode *next;//定义结点指针 }nodetype; 2)创建单链表

nodetype *create()//建立单链表,由用户输入各结点data域之值,//以0表示输入结束 { elemtype d;//定义数据元素d nodetype *h=NULL,*s,*t;//定义结点指针 int i=1; cout<<"建立一个单链表"<> d; if(d==0) break;//以0表示输入结束 if(i==1)//建立第一个结点 { h=(nodetype*)malloc(sizeof(nodetype));//表示指针h h->data=d;h->next=NULL;t=h;//h是头指针 } else//建立其余结点 { s=(nodetype*) malloc(sizeof(nodetype)); s->data=d;s->next=NULL;t->next=s; t=s;//t始终指向生成的单链表的最后一个节点

数据结构实验报告(四)

《数据结构》实验报告 班级: 学号: 姓名:

实验四二叉树的基本操作实验环境:Visual C++ 实验目的: 1、掌握二叉树的二叉链式存储结构; 2、掌握二叉树的建立,遍历等操作。 实验内容: 通过完全前序序列创建一棵二叉树,完成如下功能: 1)输出二叉树的前序遍历序列; 2)输出二叉树的中序遍历序列; 3)输出二叉树的后序遍历序列; 4)统计二叉树的结点总数; 5)统计二叉树中叶子结点的个数; 实验提示: //二叉树的二叉链式存储表示 typedef char TElemType; typedef struct BiTNode{ TElemType data; struct BiTNode *lchild,*rchild; }BiTNode,*BiTree;

一、程序源代码 #include #include #define MAXSIZE 30 typedef char ElemType; typedef struct TNode *BiTree; struct TNode { char data; BiTree lchild; BiTree rchild; }; int IsEmpty_BiTree(BiTree *T) { if(*T == NULL) return 1; else return 0;

} void Create_BiTree(BiTree *T){ char ch; ch = getchar(); //当输入的是"#"时,认为该子树为空 if(ch == '#') *T = NULL; //创建树结点 else{ *T = (BiTree)malloc(sizeof(struct TNode)); (*T)->data = ch; //生成树结点 //生成左子树 Create_BiTree(&(*T)->lchild); //生成右子树 Create_BiTree(&(*T)->rchild); } } void TraverseBiTree(BiTree T) { //先序遍历 if(T == NULL) return;

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 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.360docs.net/doc/3110898218.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.360docs.net/doc/3110898218.html,st) { cout<<"error1"<

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

数据结构实验报告模板

2009级数据结构实验报告 实验名称:约瑟夫问题 学生姓名:李凯 班级:21班 班内序号:06 学号:09210609 日期:2010年11月5日 1.实验要求 1)功能描述:有n个人围城一个圆圈,给任意一个正整数m,从第一个人开始依次报数,数到m时则第m个人出列,重复进行,直到所有人均出列为止。请输出n个人的出列顺序。 2)输入描述:从源文件中读取。 输出描述:依次从显示屏上输出出列顺序。 2. 程序分析 1)存储结构的选择 单循环链表 2)链表的ADT定义 ADT List{ 数据对象:D={a i|a i∈ElemSet,i=1,2,3,…n,n≧0} 数据关系:R={< a i-1, a i>| a i-1 ,a i∈D,i=1,2,3,4….,n} 基本操作: ListInit(&L);//构造一个空的单链表表L ListEmpty(L); //判断单链表L是否是空表,若是,则返回1,否则返回0. ListLength(L); //求单链表L的长度 GetElem(L,i);//返回链表L中第i个数据元素的值; ListSort(LinkList&List) //单链表排序 ListClear(&L); //将单链表L中的所有元素删除,使单链表变为空表 ListDestroy(&L);//将单链表销毁 }ADT List 其他函数: 主函数; 结点类; 约瑟夫函数 2.1 存储结构

[内容要求] 1、存储结构:顺序表、单链表或其他存储结构,需要画示意图,可参考书上P59 页图2-9 2.2 关键算法分析 结点类: template class CirList;//声明单链表类 template class ListNode{//结点类定义; friend class CirList;//声明链表类LinkList为友元类; Type data;//结点的数据域; ListNode*next;//结点的指针域; public: ListNode():next(NULL){}//默认构造函数; ListNode(const Type &e):data(e),next(NULL){}//构造函数 Type & GetNodeData(){return data;}//返回结点的数据值; ListNode*GetNodePtr(){return next;}//返回结点的指针域的值; void SetNodeData(Type&e){data=e;}//设置结点的数据值; void SetNodePtr(ListNode*ptr){next=ptr;} //设置结点的指针值; }; 单循环链表类: templateclass CirList { ListNode*head;//循环链表头指针 public: CirList(){head=new ListNode();head->next=head;}//构造函数,建立带头节点的空循环链表 ~CirList(){CirListClear();delete head;}//析构函数,删除循环链表 void Clear();//将线性链表置为空表 void AddElem(Type &e);//添加元素 ListNode *GetElem(int i)const;//返回单链表第i个结点的地址 void CirListClear();//将循环链表置为空表 int Length()const;//求线性链表的长度 ListNode*ListNextElem(ListNode*p=NULL);//返回循环链表p指针指向节点的直接后继,若不输入参数,则返回头指针 ListNode*CirListRemove(ListNode*p);//在循环链表中删除p指针指向节点的直接后继,且将其地址通过函数值返回 CirList&operator=(CirList&List);//重载赋

数据结构实验二叉树

实验六:二叉树及其应用 一、实验目的 树是数据结构中应用极为广泛的非线性结构,本单元的实验达到熟悉二叉树的存储结构的特性,以及如何应用树结构解决具体问题。 二、问题描述 首先,掌握二叉树的各种存储结构和熟悉对二叉树的基本操作。其次,以二叉树表示算术表达式的基础上,设计一个十进制的四则运算的计算器。 如算术表达式:a+b*(c-d)-e/f 三、实验要求 如果利用完全二叉树的性质和二叉链表结构建立一棵二叉树,分别计算统计叶子结点的个数。求二叉树的深度。十进制的四则运算的计算器可以接收用户来自键盘的输入。由输入的表达式字符串动态生成算术表达式所对应的二叉树。自动完成求值运算和输出结果。四、实验环境 PC微机 DOS操作系统或 Windows 操作系统 Turbo C 程序集成环境或 Visual C++ 程序集成环境 五、实验步骤 1、根据二叉树的各种存储结构建立二叉树; 2、设计求叶子结点个数算法和树的深度算法; 3、根据表达式建立相应的二叉树,生成表达式树的模块; 4、根据表达式树,求出表达式值,生成求值模块; 5、程序运行效果,测试数据分析算法。 六、测试数据 1、输入数据:*(+)3 正确结果: 2、输入数据:(1+2)*3+(5+6*7);

正确输出:56 七、表达式求值 由于表达式求值算法较为复杂,所以单独列出来加以分析: 1、主要思路:由于操作数是任意的实数,所以必须将原始的中缀表达式中的操作数、操作符以及括号分解出来,并以字符串的形式保存;然后再将其转换为后缀表达式的顺序,后缀表达式可以很容易地利用堆栈计算出表达式的值。 例如有如下的中缀表达式: a+b-c 转换成后缀表达式为: ab+c- 然后分别按从左到右放入栈中,如果碰到操作符就从栈中弹出两个操作数进行运算,最后再将运算结果放入栈中,依次进行直到表达式结束。如上述的后缀表达式先将a 和b 放入栈中,然后碰到操作符“+”,则从栈中弹出a 和b 进行a+b 的运算,并将其结果d(假设为d)放入栈中,然后再将c 放入栈中,最后是操作符“-”,所以再弹出d和c 进行d-c 运算,并将其结果再次放入栈中,此时表达式结束,则栈中的元素值就是该表达式最后的运算结果。当然将原始的中缀表达式转换为后缀表达式比较关键,要同时考虑操作符的优先级以及对有括号的情况下的处理,相关内容会在算法具体实现中详细讨论。 2、求值过程 一、将原始的中缀表达式中的操作数、操作符以及括号按顺序分解出来,并以字符串的 形式保存。 二、将分解的中缀表达式转换为后缀表达式的形式,即调整各项字符串的顺序,并将括 号处理掉。 三、计算后缀表达式的值。 3、中缀表达式分解 DivideExpressionToItem()函数。分解出原始中缀表达式中的操作数、操作符以及括号,保存在队列中,以本实验中的数据为例,分解完成后队列中的保存顺序如下图所示:

《数据结构》实验指导书

《数据结构》实验指导书 实验类别:课内实验实验课程名称:数据结构 实验室名称:软件工程实验室实验课程编号: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学时)

数据结构实验指导书(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; }

相关文档
最新文档