数据结构实验指导书(C语言版)-罗先文

数据结构实验指导书(C语言版)-罗先文
数据结构实验指导书(C语言版)-罗先文

——信息管理系

《数据结构》实验指导书《DATA STRUCTURES》

罗先文

LUOXIANWEN

西南大学信息管理系Iinformation dept. SouthWest University

January 24, 2010

写在上机实习之前

上机实践是学生对本门课程所学知识的一种全面、综合的能力训练,是与课堂听讲、自学和练习相辅相成的必不可少的一个教学环节,也是对课堂教学与实践教学效果的一种检验。通常,实习题中的问题比平时的习题复杂得多,也更接近实际。实习着眼于原理与应用的结合,使学生学会如何把书上学到的知识运用于解决实际问题的过程中去,培养从事软件开发设计工作所必需的基本技能;另一方面,能使书上的知识变“活”,起到深化理解和灵活掌握教学内容的目的。平时的练习较偏重于如何编写功能单一的“小”算法,而实习题是软件设计的综合训练,包括问题分析,总体结构设计,用户界面设计,程序设计基本技能和技巧,多人合作,以至一整套软件工程规范的训练和科学作风的培养。此外,还有很重要的一点是:机器是比任何教师都严厉的主考者。

为了达到上述目的,本篇安排了7个主实习单元,各单元的训练重点在于基本的数据结构,而不强调面面俱到。各实习单元与教科书的各章具有紧密的对应关系,在个别实习单元中安排有难度差别不等的多个实习题,以便学生选做。

此外,每个实习题采取了统一的格式,实验目的、实验内容、实验要求、程序实现、程序运行情况和源程序清单等5个部分组成。

在每个实习单元都提供了一个完整的实现代码,仅供同学们参考,绝大多数的同学在上机实习时千万不要机械的照抄本附录所提供的范文。而是应该自己独立的思考和设计你的算法和程序,并争取在规定的时间内如期完成上机工作任务。对于个别成绩较差的同学,实在是没法完成任务的建议你不妨抄一遍附录中的样题,以增强你的感性认识,强化你的实践基础,提高你的实践能力。本附录样题全部用c语言编写,并全部上机调试通过,但由于时间比较仓促,样题中提供的算法和程序并不是最好的算法和程序,相信不少的同学一定有能力设计出更好的算法和程序。随着计算机学科的不断发展,可以使用的语言工具越来越丰富,在本篇中的实习示例还只是应用面向过程的语言进行设计和编写的程序,同样的实习题,读者也可以用面向对象的语言来实现。我们希望实习报告示例能起到一个抛砖引玉的作用,在经过同学们的努力学习和积极使用以后,更多更优良的设计范例能不断涌现。

文中存在的不妥之处,敬请各位不吝赐教!

目录

《数据结构》实验大纲 (4)

实验一、线性表操作 (2)

实验二、栈和队列的应用 (6)

实验三、多维数组和串 (12)

实验四、树和二叉树的操作 (17)

实验五、图的操作 (23)

实验六、各种查找操作 (30)

实验七、各种排序操作 (37)

《数据结构》实验大纲

一.课程名称:数据结构及算法分析

课程编号:

课程学时:70

课程学分:3.5

实验时数:20

二.所属实验室名称:计算机中心

三.实验教材及参考书:

【1】数据结构题集(C语言版)清华大学出版社2000年

【2】DATA STRUCTURES WITH C++ 清华大学出版社

【3】本材料之后的附录

四.实验内容和目的:

掌握四种基本数据结构:集合、线性结构、树形结构、网状结构在求解实际问题中的应用,以及培养书写规范文档的技巧。学习基本的查找和排序技术。要求学生具有编制相当规模的程序的能力。养成一种良好的程序设计风格。

五.考核方式:上机考试、编程并运行通过。

六.实验环境:

硬件最低要求:586微型计算机,主频450MHZ以上,内存64MB以上,硬盘10G,有软驱。

每个学生每次上机实验使用一台计算机。

软件:C语言或Visual C++6.0

七.实验项目及安排

实验一、线性表操作

一、实验目的

1.掌握用C语言调试程序的基本方法。

2.掌握线性表的基本运算,如插入、删除等。

二、实验内容

1.线性表在顺序存储结构上的插入元素,删除元素运算

2.线性表在链式存储结构上的建链表,插入结点,删除结点运算

三、实验要求

1.1.C++/C完成算法设计和程序设计并上机调试通过。

2.2.撰写实验报告,提供实验结果和数据。

3.3.分析算法,要求给出具体的算法分析结果,包括时间复杂度和空间复杂度,并简要给出算法设计小结和心得。

四、程序实现

写出每个操作的算法(操作过程)

五、程序运行情况

写出输入数据及运行结果

六、源程序清单。

程序1:顺序存储的线性表和运算

#include

#define MAXSIZE 100

int list[MAXSIZE];

int n;

/*insert in a seqlist*/

int sq_insert(int list[], int *p_n, int i, int x)

{int j;

if (i<0 || i>*p_n) return(1);

if (*p_n==MAXSIZE) return(2);

for (j=*p_n+1; j>i; j--)

list[j]=list[j-1];

list[i]=x;

(*p_n)++;

return(0);

}

/*delete in a seq list*/

int sq_delete(int list[], int *p_n, int i)

{int j;

if (i<0 || i>=*p_n) return(1);

for (j = i+1; j<=*p_n; j++)

list[j-1] = list[j];

(*p_n)--;

return(0);

}

void main()

{int i,x,temp;

printf("please input the number for n\n");

printf("n=");

scanf("%d",&n);

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

{printf("list[%d]=",i);

scanf("%d",&list[i]);}

printf("The list before insertion is\n");

for (i=0; i<=n; i++) printf("%d ",list[i]);

printf("\n");

printf("please input the position where you want to insert a value\nposition=");

scanf("%d",&i);

printf("please input the value you want to insert.\nx=");

scanf("%d",&x);

temp=sq_insert(list,&n,i,x);

switch(temp)

{case 0:printf("The insertion is successful!\n");

printf("The list is after insertion is\n");

for(i=0; i<=n; i++) printf("%d ",list[i]);

printf("\n");

printf("%d\n",n);

break;

case 1:

case 2:printf("The insertion is not successful!\n");break;}

/*deleting*/

printf("The list before deleting is\n");

for (i=0; i<=n; i++) printf("%d ",list[i]);

printf("\n");

printf("please input the position where you want to delete a value\nposition=");

scanf("%d",&i);

temp=sq_delete(list,&n,i);

switch(temp)

{case 0:printf("The deleting is successful!\n");

printf("The list is after deleting is\n");

for(i=0; i<=n; i++) printf("%d ",list[i]);

printf("\n");

printf("%d",n);

break;

case 1:printf("The deleting is not successful!");break;}

}

程序2链式存储的线性表和运算

#include

#include

struct node{

char data;

struct node *next;

};

typedef struct node NODE;

/*This function creates a link_list with N nodes.*/

NODE *create_link_list(int n)

{int i;

NODE *head, *p, *q;

if (n==0) return NULL;

head = (NODE *) malloc(sizeof(NODE));

p = head;

printf("Please input %d chars for the link list\n",n);

for (i=0; i

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

q=(NODE *)malloc(sizeof(NODE));

printf("test3\n");

p->next=q;

p=q;}

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

getchar();

p->next=NULL;

return (head);}

/*This function inserts a node whose value is b*/

/*before the node whose value is a, if the node is not exist,*/ /*then insert it at the end of the list*/

void insert(NODE **p_head, char a, char b)

{NODE *p, *q;

q = (NODE *)malloc(sizeof(NODE));

q->data = b;

q->next =NULL;

if (* p_head == NULL) * p_head = q;

else

{p=(NODE*)malloc(sizeof(NODE));

p = * p_head;

while (p->data != a && p->next != NULL)

p = p->next;

q->next = p->next;

p->next = q;}

}

/*The function deletes the node whose value is a,*/

/*if success, return 0, or return 1*/

int deletenode(NODE **p_head, char a)

{NODE *p, *q;

q=*p_head;

if (q==NULL) return(1);

if (q->data == a)

{* p_head = q->next;

free(q);

return (0);}

else

{while (q->data != a && q->next != NULL)

{p = q;

q = q->next;}

if (q->data == a)

{p->next = q->next;

free(q);

return(0);}

else return(1);}

}

void main()

{ NODE *my_head,*p;

/* create a link list with m nodes */

int m;

char ch_a,ch_b;

printf("please input the number of nodes for the link_list\nm=");

scanf("%d",&m);

getchar();

printf("test1\n");

my_head = (NODE *) malloc(sizeof(NODE));

my_head=create_link_list(m);

/*Output the link list*/

printf("The link list is like:\n");

p=my_head;

while (p != NULL)

{printf("%c ",p->data);

p=p->next;

}

printf("\n");

/*insert a node whose value is b before a*/

printf("Please input the position for a\n ch_a=");

getchar();

scanf("%c",&ch_a);

getchar();

printf("Please input the value that you want to insert\n ch_b=");

scanf("%c",&ch_b);

getchar();

insert(&my_head,ch_a,ch_b);

printf("The link list after insertion is like:\n");

p=my_head;

while (p != NULL)

{printf("%c ",p->data);

p=p->next;

}

printf("\n");

/*delete a node whose value is a*/

printf("Please input the position for a a=");

scanf("%c",&ch_a);

getchar();

deletenode(&my_head,ch_a);

printf("The link list after deleting is like:\n");

p=my_head;

while (p != NULL)

{printf("%c ",p->data);

p=p->next;

}

printf("\n");

}

实验二、栈和队列的应用

一、实验目的

1、掌握栈的特点(先进后出FILO)及基本操作,如入栈、出栈等,栈的顺序存储结构和链式存储结构,以便在实际问题背景下灵活应用。

2、掌握队列的特点(先进先出FIFO)及基本操作,如入队、出队等,队列顺序存储结构、链式存储结构和循环队列的实现,以便在实际问题背景下灵。

二、实验内容

1.顺序栈的实现和运算

2.链栈的实现和运算

3.顺序队列的实现和运算

4.链式队列的实现和运算

5.循环队列的实现和运算

三、实验要求

1.用C++/C完成算法设计和程序设计并上机调试通过。

2.撰写实验报告,提供实验结果和数据。

3.分析算法,要求给出具体的算法分析结果,包括时间复杂度和空间复杂度,并简要给出算法设计小结和心得。

四、程序实现

写出每个操作的算法(操作过程)

程序运行情况

五、写出输入数据及运行结果

六、源程序清单。

程序1:顺序栈的实现和运算

#include

#define MAXN 26

char stack[MAXN];

int top=0;

int push(char x)

{if (top >= MAXN)

return(1);

stack[top++]=x;

return(0);

}

int pop(char *p_y)

{if (top == 0)

return(1);

*p_y = stack[--top];

return(0);

}

void main()

{ int i;

char ch_x,ch_y;

printf("input the char you want to push\n");

scanf("%c",&ch_x);

while(ch_x!='0')

if (push(ch_x)==1) printf("failure!\n");

else

{printf("success!\n");

printf("input a char for ch_x to push\nch_x=");

getchar();

scanf("%c",&ch_x);}

i=0;

while(stack[i]!='\0')

{printf("%c ", stack[i]);

i++;}

if (pop(&ch_y)==1) printf("failure!\n");

else

{printf("success!\n");

printf("The pop char is %c\n",ch_y);}

for (i=top-1; i>=0; i--)

printf("%c ", stack[i]);

}

程序2:链栈的实现和运算

#include

#include

struct node{char data;

struct node *link;

};

typedef struct node NODE;

NODE * top = NULL;

void push_l(char x)

{NODE *p;

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

p->data = x;

p->link = top;

top = p;

}

int pop_l(char *p_y)

{NODE *p;

if (top == NULL)

return(1);

* p_y = top->data;

p = top;

top = top->link;

free(p);

return(0);

}

void main()

{ NODE *p;

char ch_x,ch_y;

printf("input the char you want to push\n");

scanf("%c",&ch_x);

while(ch_x!='0')

{push_l(ch_x);

getchar();

scanf("%c",&ch_x);}

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

p=top;

while(p!=NULL)

{printf("%c ",p->data);

p=p->link;}

printf("\n");

if (pop_l(&ch_y)==1) printf("failure!\n");

else

{printf("success!\n");

printf("The pop char is %c\n",ch_y);}

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

p=top;

while(p!=NULL)

{printf("%c ",p->data);

p=p->link;}

printf("\n");

}

程序3:顺序队列的实现和运算

#include

#define MAXN 26

char q[MAXN];

int head = -1, tail = -1;

int en_queue(char x )

{if (tail == MAXN-1)

return(1);

q[++tail] = x;

return(0);

}

int de_queue(char *p_y )

{if (head == tail)

return(1);

*p_y = q[++head];

return(0);

}

void main()

{ int i;

char ch_x,ch_y;

printf("input the char you want to enqueue\n");

scanf("%c",&ch_x);

while(ch_x!='0')

if (en_queue(ch_x)==1) printf("failure!\n");

else

{printf("success!\n");

printf("input a char for ch_x to enqueue\nch_x=");

getchar();

scanf("%c",&ch_x);}

i=1;

while(q[i]!='\0')

{printf("%c ", q[i]);

i++;}

if (de_queue(&ch_y)==1) printf("failure!\n");

else

{printf("success!\n");

printf("The dequeue char is %c\n",ch_y);}

for (i=head+1; i<=tail; i++)

printf("%c ", q[i]);

}

程序4:链式队列的实现和运算

#include

#include"

struct node{char data;

struct node * link;

};

typedef struct node NODE;

NODE *head, *tail;

void en_queue_l(char x)

{NODE *p;

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

p->data = x;

p->link = NULL;

if (head == NULL)

head = p;

else

tail->link = p;

tail = p;

}

int de_queue_l(char *p_y)

{NODE *p;

if (head == NULL)

return(1);

*p_y = head->data;

p = head;

head = head->link;

free(p);

return(0);

}

void main()

{ NODE *p;

char ch_x,ch_y;

scanf("%c",&ch_x);

while(ch_x!='0')

{en_queue_l(ch_x);

getchar();

scanf("%c",&ch_x);}

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

p=head;

while(p!=NULL)

{printf("%c ",p->data);

p=p->link;}

printf("\n");

if (de_queue_l(&ch_y)==1) printf("failure!\n");

else

{printf("success!\n");

printf("The dequeue char is %c\n",ch_y);} p=(NODE*)malloc(sizeof(NODE));

p=head;

while(p!=NULL)

{printf("%c ",p->data);

p=p->link;}

printf("\n");

}

程序5:循环队列的实现和运算

#include

#include

#define MAXN 26

char q[MAXN];

int head = 0, tail = 0;

int en_c_q(char x)

{tail = (tail + 1) % MAXN;

if (tail == head)

{if (tail == 0) tail = MAXN-1;

else tail--;

return(1);}

q[tail] = x;

return(0);

}

int de_c_q(char *p_y)

{if (head == tail)

return(1);

head = (head+1) % MAXN;

*p_y = q[head];

return(0);}

void main()

{ int i;

char ch_x,ch_y;

scanf("%c",&ch_x);

while(ch_x!='0')

if (en_c_q(ch_x)==1) printf("failure!\n");

else

{printf("success!\n");

printf("input a char for ch_x to enqueue\nch_x=");

getchar();

scanf("%c",&ch_x);}

i=1;

while(q[i]!='\0')

{printf("%c ", q[i]);

i++;}

if (de_c_q(&ch_y)==1) printf("failure!\n");

else

{printf("success!\n");

printf("The dequeue char is %c\n",ch_y);}

for (i=head+1; i<=tail; i++)

printf("%c ", q[i]);

}

实验三、多维数组和串

一、实验目的

1.掌握稀疏矩阵的特点(三元组存储方法)。

2.掌握串的运算(赋值,比较,联结,插入子串,模式匹配……等)。

二、实验内容

1.稀疏矩阵的存储及转置运算

2.串的基本操作

三、实验要求

1.用C++/C完成算法设计和程序设计并上机调试通过。

2.撰写实验报告,提供实验结果和数据。

3.分析算法,要求给出具体的算法分析结果,包括时间复杂度和空间复杂度,并简要给出算法设计小结和心得。

四、程序实现

写出每个操作的算法(操作过程)

程序运行情况

五、写出输入数据及运行结果

六、源程序清单。

程序1:稀疏矩阵的存储及转置运算

#include

typedef struct {

int row ;

int col ;

int val ;

}THA ;

#define MAX 20

main( )

{ int i, j, count=1 ;

int col, row, val ;

THA s[MAX];

THA t[MAX];

printf("input the number of row ,col and elements:");

scanf("%d,%d,%d",&s[0].row,&s[0].col,&s[0].val);

if(s[0].val==0) return ;

val =s[0].val;

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

scanf("%d,%d,%d",&s[i].row,&s[i].col,&s[i].val);

row = s[0].row ;

col= s[0].col ;

count=1 ;

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

for ( j=1; j<=val ; j++)

if (s[j].col==i)

{

t[count].row = s[j].col;

t[count].col = s[j].row;

t[count++].val = s[j].val;

}

t[0].row = col ;

t[0].col = row ;

t[0].val = val ;

for(i=0;i<=val;i++)

printf("%d,%d,%d\n",t[i].row,t[i].col,t[i].val);

}

程序2:串的实现和运算

#include

#define MAXN 128

typedef enum {fail,success} status;

typedef enum {false,true} boolean;

main()

{ int strlen();

void strass();

boolean strcmp();

status strcat( );

status strins();

void patmatch();

int t,n,i;

boolean b;

status st;

char s[MAXN],s1[MAXN],s2[MAXN];

printf("\n1. The length of string\n");

printf(" 2. The assignment of string\n");

printf(" 3. A string compare with another string:\n");

printf(" 4. A string connect with another string:\n");

printf(" 5. A string to be inserted into another string\n"); printf(" 6. The pattern match of string :");

printf(" Please input a opertation:");

scanf("%d",&t);

switch(t)

{ case 1:

printf("please input a string:\n");

getchar();

gets(s);

n=strlen(s);

printf("the length is: %d",n);

break;

case 2:

printf("please input the first string:\n");

getchar();

gets(s1);

printf("please input the second string:\n");

getchar();

gets(s2);

strass(s1,s2);

break;

case 3:

printf("please input the first string:\n");

getchar();

gets(s1);

printf("please input the second string: \n");

gets(s2);

b=strcmp(s1,s2);

if (b==true)

printf("equal\n");

else

printf("not equal\n");

break;

case 4:

printf("please input the first string:\n");

getchar();

gets(s1);

printf("please input the second string:\n");

gets(s2);

st=strcat(s1,s2);

if(st==success)

printf("answer is %s\n",s1);

else

printf("error!\n");

break;

case 5:

printf("please input the first string:\n");

getchar();

gets(s1);

printf("please input the second string:\n");

gets(s2);

printf("please input i:");

scanf("%d",&i);

st=strins(s1,i,s2);

if(st==success)

printf("answer is %s\n",s1);

else printf("error!\n");

break;

case 6:

patmatch();

break;

default: printf("There isn't this operation!"); }

}

int strlen(s)

char s[];

{ int i;

for(i=0;s[i]!='\0';i++);

return (i);

}

void strass(s1,s2)

char s1[],s2[];

{ int i=0;

while(s1[i]!='\0')

{ s2[i]=s1[i];

i++;

}

s2[i]='\0';

printf("s2 is %s",s2);

}

boolean strcmp(s1,s2)

char s1[],s2[];

{ int i=0;

while (s1[i]==s2[i] && s1[i]!='\0' && s2[i]!='\0') i++;

if (s1[i]=='\0' && s2[i]=='\0')

return (true);

else

return (false);

}

status strcat (s1,s2)

char s1[],s2[];

{ int i,j,k;

i=strlen(s1);

j=strlen(s2);

if((i+j)>=MAXN)

return(fail);

for(k=0;k<=j;k++)

s1[i+k]=s2[k];

return (success);

}

status strins (s1,i,s2)

char s1[],s2[];

int i;

{ int m,n,k;

m=strlen(s1);

n=strlen(s2);

if (i<0||i>m||(m+n)>MAXN )

return (fail) ;

for(k=m;k>=i;k--)

s1[k+n]=s1[k];

for(k=0;k

s1[i+k]=s2[k];

return (success);

}

int smatch(ch,n,pat,m)

char ch[],pat[];

int n,m;

{ int s,p,k;

for(s=0;s<=n-m;s++)

{

for(p=0,k=s;p

if(p==m)return(s+1);

}

return(-1);

}

void patmatch()

{ char ch[MAXN],pat[MAXN];

int n,m, result;

printf("\ninput the primary string:\n");

scanf("%s",ch);

printf("input the pattern string:\n");

scanf("%s",pat);

n=strlen(ch);

m=strlen(pat);

result=smatch(ch,n,pat,m);

if(result==-1)printf("\nNo matched found!");

else if(result>=0) printf("\nMatched sub string found in position %d",result); }

实验四、树和二叉树的操作

一、实验目的

1.进一步掌握树的结构及非线性特点,递归特点和动态性。

2.进一步巩固对指针的使用和二叉树的三种遍历方法、建立方法及用广义表进行输入输出。

二、实验内容

1.二叉树的实现和运算

2.线索二叉树的实现

3.哈夫曼树的实现

三、实验要求

1.用C++/C完成算法设计和程序设计并上机调试通过。

2.撰写实验报告,提供实验结果和数据。

3.分析算法,要求给出具体的算法分析结果,包括时间复杂度和空间复杂度,并简要给出算法设计小结和心得。

四、程序实现

写出每个操作的算法(操作过程)

程序运行情况

五、写出输入数据及运行结果

六、源程序清单。

程序1:二叉树的实现和运算

#include

#include

#include

typedef struct btnode

{char data; /*suppose the data field's type is char*/

struct btnode *lchild; /*left pointer field */

struct btnode *rchild; /*right pointer field */

}NODE;

void main()

{ NODE *root,*q,n;

NODE *create(NODE *p);

void preorder(NODE *root);

void inorder(NODE *root);

void postorder(NODE *root);

int t;

q=&n;

root=create(q);

printf("At the first,we create a tree\n");

printf("Please input nodes of tree\n");

if (root==NULL) printf("It's an empty tree!\n");

else

{

printf("\n1.The preordetraverse \n");

printf(" 2.The inordertraverse \n");

printf(" 3.The postordertraverse \n");

printf(" Please choose a kind of order\n");

scanf("%d",&t);

数据结构课程实验指导书

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

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

数据结构实验答案1

重庆文理学院软件工程学院实验报告册 专业:_____软件工程__ _ 班级:_____软件工程2班__ _ 学号:_____201258014054 ___ 姓名:_____周贵宇___________ 课程名称:___ 数据结构 _ 指导教师:_____胡章平__________ 2013年 06 月 25 日

实验序号 1 实验名称实验一线性表基本操作实验地点S-C1303 实验日期2013年04月22日 实验内容1.编程实现在顺序存储的有序表中插入一个元素(数据类型为整型)。 2.编程实现把顺序表中从i个元素开始的k个元素删除(数据类型为整型)。 3.编程序实现将单链表的数据逆置,即将原表的数据(a1,a2….an)变成 (an,…..a2,a1)。(单链表的数据域数据类型为一结构体,包括学生的部分信息:学号,姓名,年龄) 实验过程及步骤1. #include #include #include #define OK 1 #define ERROR 0 #define TRUE 1 #define FALSE 0 #define ElemType int #define MAXSIZE 100 /*此处的宏定义常量表示线性表可能达到的最大长度*/ typedef struct

{ ElemType elem[MAXSIZE]; /*线性表占用的数组空间*/ int last; /*记录线性表中最后一个元素在数组elem[ ]中的位置(下标值),空表置为-1*/ }SeqList; #include "common.h" #include "seqlist.h" void px(SeqList *A,int j); void main() { SeqList *l; int p,q,r; int i; l=(SeqList*)malloc(sizeof(SeqList)); printf("请输入线性表的长度:"); scanf("%d",&r); l->last = r-1; printf("请输入线性表的各元素值:\n"); for(i=0; i<=l->last; i++) { scanf("%d",&l->elem[i]); } px(l,i); printf("请输入要插入的值:\n");

数据结构实验指导书(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) 附:实验报告模板 .......... 错误!未定义书签。

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

(完整版)数据结构实验报告全集

数据结构实验报告全集 实验一线性表基本操作和简单程序 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 始终指向生成的单链表的最后一个节点

数据结构实验报告代码

线性表 代码一 #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) {

《数据结构》实验报告

苏州科技学院 数据结构(C语言版) 实验报告 专业班级测绘1011 学号10201151 姓名XX 实习地点C1 机房 指导教师史守正

目录 封面 (1) 目录 (2) 实验一线性表 (3) 一、程序设计的基本思想,原理和算法描述 (3) 二、源程序及注释(打包上传) (3) 三、运行输出结果 (4) 四、调试和运行程序过程中产生的问题及采取的措施 (6) 五、对算法的程序的讨论、分析,改进设想,其它经验教训 (6) 实验二栈和队列 (7) 一、程序设计的基本思想,原理和算法描述 (8) 二、源程序及注释(打包上传) (8) 三、运行输出结果 (8) 四、调试和运行程序过程中产生的问题及采取的措施 (10) 五、对算法的程序的讨论、分析,改进设想,其它经验教训 (10) 实验三树和二叉树 (11) 一、程序设计的基本思想,原理和算法描述 (11) 二、源程序及注释(打包上传) (12) 三、运行输出结果 (12) 四、调试和运行程序过程中产生的问题及采取的措施 (12) 五、对算法的程序的讨论、分析,改进设想,其它经验教训 (12) 实验四图 (13) 一、程序设计的基本思想,原理和算法描述 (13) 二、源程序及注释(打包上传) (14) 三、运行输出结果 (14) 四、调试和运行程序过程中产生的问题及采取的措施 (15) 五、对算法的程序的讨论、分析,改进设想,其它经验教训 (16) 实验五查找 (17) 一、程序设计的基本思想,原理和算法描述 (17)

二、源程序及注释(打包上传) (18) 三、运行输出结果 (18) 四、调试和运行程序过程中产生的问题及采取的措施 (19) 五、对算法的程序的讨论、分析,改进设想,其它经验教训 (19) 实验六排序 (20) 一、程序设计的基本思想,原理和算法描述 (20) 二、源程序及注释(打包上传) (21) 三、运行输出结果 (21) 四、调试和运行程序过程中产生的问题及采取的措施 (24) 五、对算法的程序的讨论、分析,改进设想,其它经验教训 (24) 实验一线性表 一、程序设计的基本思想,原理和算法描述: 程序的主要分为自定义函数、主函数。自定义函数有 InitList_Sq、Out_List、ListInsert_Sq、ListDelete_Sq、LocateElem_Sq 、compare。主函数在运行中调用上述的自定义函数,每个自定义函数实现程序的每部分的小功能。 1.程序设计基本思想 用c语言编译程序,利用顺序存储方式实现下列功能:根据键盘输入数据建立一个线性表,并输出该线性表;然后根据屏幕菜单的选择,可以进行数据的插入、删除、查找,并在插入或删除数据后,再输出线性表;最后在屏幕菜单中选择结束按钮,即可结束程序的运行。 2.原理 线性表通过顺序表现,链式表示,一元多项式表示,其中链式表示又分为静态链表,双向链表,循环链表等,在不同的情况下各不相同,他可以是一个数字,也可以是一个符号,通过符号或数字来实现程序的运行。 3.算法描述

数据结构实验指导书

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

数据结构实验报告(2015级)及答案

数据结构实验报告(2015级)及答案

《数据结构》实验报告 专业__信息管理学院______ 年级__2015级___________ 学号___ _______ 学生姓名___ _ _______ 指导老师____________ 华中师范大学信息管理系编

I 实验要求 1.每次实验中有若干习题,每个学生至少应该完成其中的两道习题。 2.上机之前应作好充分的准备工作,预先编好程序,经过人工检查无误后,才能上机,以提高上机效率。 3.独立上机输入和调试自己所编的程序,切忌抄袭、拷贝他人程序。 4.上机结束后,应整理出实验报告。书写实验报告时,重点放在调试过程和小节部分,总结出本次实验中的得与失,以达到巩固课堂学习、提高动手能力的目的。 II 实验内容 实验一线性表 【实验目的】 1.熟悉VC环境,学习如何使用C语言实现线性表的两种存储结构。 2.通过编程、上机调试,进一步理解线性表的基本概念,熟练运用C语言实现线性表基本操作。 3.熟练掌握线性表的综合应用问题。 【实验内容】 1.一个线性表有n个元素(n

的顺序不变。设计程序实现。要求:采用顺序存储表示实现;采用链式存储表示方法实现;比较两种方法的优劣。 2. 从单链表中删除指定的元素x,若x在单链表中不存在,给出提示信息。 要求: ①指定的值x由键盘输入; ②程序能处理空链表的情况。 3.设有头结点的单链表,编程对表中的任意值只保留一个结点,删除其余值相同的结点。 要求: ①该算法用函数(非主函数)实现; ②在主函数中调用创建链表的函数创建一个单链表, 并调用该函数,验证算法的正确性。 LinkedList Exchange(LinkedList HEAD,p)∥HEAD是单链表头结点的指针,p是链表中的一个结点。本算法将p所指结点与其后 继结点交换。 {q=head->next;∥q是工作指针,指向链表中当前待处理结点。 pre=head;∥pre是前驱结点指针,指向q的前驱。 while(q!=null && q!=p){pre=q;q=q->next;} ∥

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<<"位置无效"<

数据结构实验报告

数据结构实验报告 一.题目要求 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

数据结构实验程序

顺序表的基本操作 #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/068008657.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/068008657.html,st) { cout<<"error1"<

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

数据结构实验报告-答案

数据结构(C语言版) 实验报告

专业班级学号姓名 实验1 实验题目:单链表的插入和删除 实验目的: 了解和掌握线性表的逻辑结构和链式存储结构,掌握单链表的基本算法及相关的时间性能分析。 实验要求: 建立一个数据域定义为字符串的单链表,在链表中不允许有重复的字符串;根据输入的字符串,先找到相应的结点,后删除之。 实验主要步骤: 1、分析、理解给出的示例程序。 2、调试程序,并设计输入数据(如:bat,cat,eat,fat,hat,jat,lat,mat,#),测 试程序的如下功能:不允许重复字符串的插入;根据输入的字符串,找到相应的结点并删除。 3、修改程序: (1)增加插入结点的功能。 (2)将建立链表的方法改为头插入法。 程序代码: #include"" #include"" #include"" #include"" typedef struct node . . 示意图:

head head head 心得体会: 本次实验使我们对链表的实质了解更加明确了,对链表的一些基本操作也更加熟练了。另外实验指导书上给出的代码是有一些问题的,这使我们认识到实验过程中不能想当然的直接编译执行,应当在阅读并完全理解代码的基础上再执行,这才是实验的意义所在。

实验2 实验题目:二叉树操作设计和实现 实验目的: 掌握二叉树的定义、性质及存储方式,各种遍历算法。 实验要求: 采用二叉树链表作为存储结构,完成二叉树的建立,先序、中序和后序以及按层次遍历 的操作,求所有叶子及结点总数的操作。 实验主要步骤: 1、分析、理解程序。 2、调试程序,设计一棵二叉树,输入完全二叉树的先序序列,用#代表虚结点(空指针), 如ABD###CE##F##,建立二叉树,求出先序、中序和后序以及按层次遍历序列,求 所有叶子及结点总数。 实验代码 #include"" #include"" #include"" #define Max 20 ertex=a; irstedge=NULL; irstedge; G->adjlist[i].firstedge=s; irstedge; R[i] 留在原位

《数据结构》实验指导书

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

数据结构实验报告-答案.doc

数据结构实验报告-答案 数据结构(C语言版)实验报告专业班级学号姓名实验1实验题目:单链表的插入和删除实验目的:了解和掌握线性表的逻辑结构和链式存储结构,掌握单链表的基本算法及相关的时间性能分析。 实验要求:建立一个数据域定义为字符串的单链表,在链表中不允许有重复的字符串;根据输入的字符串,先找到相应的结点,后删除之。 实验主要步骤:1、分析、理解给出的示例程序。 2、调试程序,并设计输入数据(如:bat,cat,eat,fat,hat,jat,lat,mat,#),测试程序的如下功能:不允许重复字符串的插入;根据输入的字符串,找到相应的结点并删除。 3、修改程序:(1)增加插入结点的功能。 (2)将建立链表的方法改为头插入法。 程序代码:#include“stdio.h“#include“string.h“#include“stdlib.h“#include“ctype. h“typedefstructnode//定义结点{chardata[10];//结点的数据域为字符串structnode*next;//结点的指针域}ListNode;typedefListNode*LinkList;//自定义LinkList单链表类型LinkListCreatListR1();//函数,用尾插入法建立带头结点的单链表LinkListCreatList(void);//函数,用头插入法建立带头结点的单链表ListNode*LocateNode();//函数,按值查找结点voidDeleteList();//函数,删除指定值的结点voidprintlist();//函数,打印链表中的所有值voidDeleteAll();//函数,删除所有结点,释放内存

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

《数据结构实验》实验题目及实验报告模板

《数据结构实验》的实验题目及实验报告模板 实验一客房管理(链表实验) ●实现功能:采用结构化程序设计思想,编程实现客房管理程序的各个功能函数,从而熟练 掌握单链表的创建、输出、查找、修改、插入、删除、排序和复杂综合应用等操作的算法 实现。以带表头结点的单链表为存储结构,实现如下客房管理的设计要求。 ●实验机时:8 ●设计要求: #include #include #include //定义客房链表结点结构 typedef struct HNode { char roomN[7]; //客房名称 float Price; //标准价格 float PriceL; //入住价格(默认值=标准价格*80%) int Beds; //床位数Beds char State[5]; //入住状态(值域:"空闲"、"入住"、"预订",默认值为"空闲") struct HNode *next; //指针域 }Hotel, *HLink; (1)实现创建客房信息链表函数void Build(HLink &H),输入(客房名称、标准价格、床位数),同时修改入住价格、入住状态为默认值,即入住价格=标准价格*80%,入住状态为”空闲”(提示:用strcpy()字符串拷贝函数)。为了提高程序调试效率,要求:用文件操作来输入客房信息(客房名称、标准价格、床位数); (2)实现输出客房信息函数void Exp(HLink H),输出所有客房的客房名称、标准价格、入住价格、床位数、入住状态; (3)函数int Find(HLink &H, char *roomN),查找房间名称为roomN的客房。如果找到,则返回该客房在链表中的位置序号(>=1),否则返回0。提示:用strcmp()字符串比较函数; (4)实现函数void updateH(HLink &H, int beds, char *state),将床位数为beds的客房入住状态改为state。提示:用strcpy()字符串拷贝函数; (5)函数void Add(HLink &H),将该链表中未入住的客房入住价格均加价20%; (6)求出入住价格最高的客房函数HLink FirstH(HLink &H),该函数内return语句返回入住价格最高的客房结点指针,返回前将该结点在链表中删除; (7)函数void MoveK1(HLink &H, int k),将单链表中倒数第k个结点移到第一个结点位置,注意:严禁采用先计算链表长度n再减k(即n-k)的方法;

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

#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;

相关文档
最新文档