数据结构实验报告Word格式文档下载.docx

上传人:b****6 文档编号:19990953 上传时间:2023-01-13 格式:DOCX 页数:17 大小:19.28KB
下载 相关 举报
数据结构实验报告Word格式文档下载.docx_第1页
第1页 / 共17页
数据结构实验报告Word格式文档下载.docx_第2页
第2页 / 共17页
数据结构实验报告Word格式文档下载.docx_第3页
第3页 / 共17页
数据结构实验报告Word格式文档下载.docx_第4页
第4页 / 共17页
数据结构实验报告Word格式文档下载.docx_第5页
第5页 / 共17页
点击查看更多>>
下载资源
资源描述

数据结构实验报告Word格式文档下载.docx

《数据结构实验报告Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《数据结构实验报告Word格式文档下载.docx(17页珍藏版)》请在冰豆网上搜索。

数据结构实验报告Word格式文档下载.docx

s1,int&

s2)

{inti;

i=1;

while(i<

=k&

&

HT[i].parent!

=0)i++;

//下面选出权值最小的结点,用s1指向其序号

s1=i;

for(i=1;

i<

=k;

i++)

{

if(HT[i].parent==0&

HT[i].weight

}

//下面选出权值次小的结点,用s2指向其序号

i!

=s1)break;

s2=i;

=s1&

//构造Huffman树,求出n个字符的编码

voidHuffmanCoding(HuffmanTree&

HT,HuffmanCode&

HC,int*w,intn)

intm,c,f,s1,s2,i,start;

char*cd;

if(n<

=1)return;

m=2*n-1;

//n个叶子n-1个结点

HT=(HuffmanTree)malloc((m+1)*sizeof(HTNode));

//0号单元未用,预分配m+1个单元

HuffmanTreep=HT+1;

w++;

//w的号单元也没有值,所以从号单元开始

=n;

i++,p++,w++)

p->

weight=*w;

parent=p->

rchild=p->

lchild=0;

for(;

=m;

++i,++p)

weight=p->

for(i=n+1;

Select(HT,i-1,s1,s2);

//选出当前权值最小的

HT[s1].parent=i;

HT[s2].parent=i;

HT[i].lchild=s1;

HT[i].rchild=s2;

HT[i].weight=HT[s1].weight+HT[s2].weight;

//从叶子到根逆向求每个字符的郝夫曼编码

HC=(HuffmanCode)malloc((n+1)*sizeof(char*));

//分配n个字符编码的头指针变量

cd=(char*)malloc(n*sizeof(char));

//分配求编码的工作空间

cd[n-1]='

'

;

//编码结束符

i++)//逐个字符求郝夫曼编码

start=n-1;

//编码结束符位置

for(c=i,f=HT[i].parent;

f!

=0;

c=f,f=HT[f].parent)//从叶子到根逆向求编码

if(HT[f].lchild==c)cd[--start]='

0'

else

cd[--start]='

1'

HC[i]=(char*)malloc((n-start)*sizeof(char));

//为第i个字符编码分配空间

strcpy(HC[i],&

cd[start]);

//从cd复制编码到HC

free(cd);

//释放工作空间

voidmain

{intn,i;

int*w;

//记录权值

char*ch;

//记录字符

HuffmanTreeHT;

HuffmanCodeHC;

cout<

<

"

请输入待编码的字符个数n="

cin>

>

n;

w=(int*)malloc((n+1)*sizeof(int));

//记录权值,号单元未用

ch=(char*)malloc((n+1)*sizeof(char));

//记录字符,号单元未用

依次输入待编码的字符data及其权值weight"

data["

数据结构实验报告2

一、实验目的及要求

1)掌握栈和队列这两种特殊的线性表,熟悉它们的特性,在实际问题背景下灵活运用它们。

本实验训练的要点是“栈”和“队列”的观点;

二、实验内容

1)利用栈,实现数制转换。

2)利用栈,实现任一个表达式中的语法检查(选做)。

3)编程实现队列在两种存储结构中的基本操作(队列的初始化、判队列空、入队列、出队列);

三、实验流程、操作步骤或核心代码、算法片段

顺序栈:

StatusInitStack(SqStack&

S)

S.base=(ElemType*)malloc(STACK_INIT_SIZE*sizeof(ElemType));

if(!

S.base)

returnERROR;

S.top=S.base;

S.stacksize=STACK_INIT_SIZE;

returnOK;

StatusDestoryStack(SqStack&

free(S.base);

StatusClearStack(SqStack&

StatusStackEmpty(SqStackS)

if(S.base==S.top)

intStackLength(SqStackS)

returnS.top-S.base;

StatusGetTop(SqStackS,ElemType&

e)

if(S.top-S.base>

=S.stacksize)

S.base=(ElemType*)realloc(S.base,(S.stacksize+STACKINCREMENT)*sizeof(ElemType));

S.base)returnERROR;

S.top=S.base+S.stacksize;

S.stacksize+=STACKINCREMENT;

*S.top++=e;

StatusPush(SqStack&

S,ElemTypee)

StatusPop(SqStack&

S,ElemType&

if(S.top==S.base)

e=*--S.top;

StatusStackTraverse(SqStackS)

ElemType*p;

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

p)returnERROR;

p=S.top;

while(p!

=S.base)//S.top上面一个...

p--;

printf("

%d"

*p);

StatusCompare(SqStack&

intflag,TURE=OK,FALSE=ERROR;

ElemTypee,x;

InitStack;

flag=OK;

请输入要进栈或出栈的元素:

);

while((x=getchar)!

='

#'

flag)

switch(x)

case'

('

:

['

{'

if(Push(S,x)==OK)

括号匹配成功!

"

break;

)'

if(Pop(S,e)==ERROR||e!

没有满足条件"

flag=FALSE;

]'

if(Pop(S,e)==ERROR||e!

}'

if(flag&

x=='

&

StackEmpty)

链队列:

StatusInitQueue(LinkQueue&

Q)

Q.front=Q.rear=

(QueuePtr)malloc(sizeof(QNode));

if(!

Q.front)returnERROR;

Q.front->

next=NULL;

StatusDestoryQueue(LinkQueue&

while(Q.front)

Q.rear=Q.front->

next;

free(Q.front);

Q.front=Q.rear;

StatusQueueEmpty(LinkQueue&

if(Q.front->

next==NULL)

StatusQueueLength(LinkQueueQ)

inti=0;

QueuePtrp,q;

p=Q.front;

while(p->

next)

i++;

q=p->

p=q;

returni;

StatusGetHead(LinkQueueQ,ElemType&

QueuePtrp;

p=Q.front->

p)

e=p->

data;

returne;

StatusClearQueue(LinkQueue&

while(Q.front->

next)

Q.front=p;

next=NULL;

Q.rear->

StatusEnQueue(LinkQueue&

Q,ElemTypee)

p=(QueuePtr)malloc(sizeof(QNode));

data=e;

next=p;

Q.rear=p;

//p->

next为空

StatusDeQueue(LinkQueue&

Q,ElemType&

if(Q.front==Q.rear)

p=Q.front->

e=p->

next=p->

if(Q.rear==p)

Q.rear=Q.front;

//只有一个元素时(不存在指向尾指针)

free(p);

StatusQueueTraverse(LinkQueueQ)

if(QueueEmpty(Q)==OK)

这是一个空队列!

while(p)

q=p;

%d<

-"

q->

data);

循环队列:

StatusInitQueue(SqQueue&

Q.base=(QElemType*)malloc(MAXQSIZE*sizeof(QElemType));

Q.base)

exit(OWERFLOW);

Q.front=Q.rear=0;

StatusEnQueue(SqQueue&

Q,QElemTypee)

if((Q.rear+1)%MAXQSIZE==Q.front)

Q.base[Q.rear]=e;

Q.rear=(Q.rear+1)%MAXQSIZE;

StatusDeQueue(SqQueue&

Q,QElemType&

if(Q.front==Q.rear)

e=Q.base[Q.front];

Q.front=(Q.front+1)%MAXQSIZE;

intQueueLength(SqQueueQ)

return(Q.rear-Q.front+MAXQSIZE)%MAXQSIZE;

StatusDestoryQueue(SqQueue&

free(Q.base);

StatusQueueEmpty(SqQueueQ)//判空

if(Q.front==Q.rear)

StatusQueueTraverse(SqQueueQ)

while(Q.front%MAXQSIZE!

=Q.rear)

Q.base[Q.front]);

Q.front++;

数据结构实验报告3

《数据结构与算法》实验报告

专业班级姓名学号

实验项目

实验一二叉树的应用

实验目的

1、进一步掌握指针变量的含义及应用。

2、掌握二叉树的结构特征,以及各种存储结构的特点及使用范围。

3、掌握用指针类型描述、访问和处理二叉树的运算。

实验内容

题目1:

编写一个程序,采用一棵二叉树表示一个家谱关系。

要求程序具有如下功能:

(1)用括号表示法输出家谱二叉树,

(2)查找某人的所有儿子,

(3)查找某人的所有祖先。

算法设计分析

(一)数据结构的定义

为了能够用二叉树表示配偶、子女、兄弟三种关系,特采用以下存储关系,则能在二叉树上实现家谱的各项运算。

二叉树型存储结构定义为:

typedefstructSNODE

{charname[MAX];

//人名

structSNODE*left;

//指向配偶结点

structSNODE*right;

//指向兄弟或子女结点

}FNODE;

(二)总体设计

实验由主函数、家谱建立函数、家谱输出函数、儿子查找函数、祖先查找函数、结点定位函数、选择界面函数七个函数共同组成。

其功能描述如下:

(1)主函数:

统筹调用各个函数以实现相应功能

(2)家谱建立函数:

与用户交互建立家族成员对应关系

voidInitialFamily(FNODE*&

head)//家谱建立函数

(3)家谱输出函数:

用括号表示法输出家谱

输出形式为:

父和母(子1和子妻1(孙1),子2和子妻2(孙2))

voidPrintFamily(FNODE*head)//家谱输出函数

(4)儿子查找函数:

在家谱中查找到某人所有的子女并输出,同时也能辨别出其是否为家族成员与是否有子女

voidFindSon(FNODE*b,charp[])//儿子查找函数

(5)祖先查找函数:

在家谱中查找到某人所有的祖先并输出,同时也能辨别出其是否为家族中成员。

intFindAncestor(FNODE*head,charson[])//祖先查找函数

(6)结点定位函数:

在家谱中找到用户输入人名所对应的结点。

FNODE*findnode(FNODE*b,charp[])//结点定位函数

(7)选择界面函数:

为便于编写程序,将用户选择部分独立为此函数。

voidPRINT(int&

n)

(三)各函数的详细设计:

1:

首先建立当前人的信息,将其左右结点置为空,

2:

然后让用户确定其是否有配偶,如果没有配偶,则当前程序结束,

3:

如果有则建立其配偶信息,并将配偶结点赋给当前人的左结点;

4:

再让用户确定其是否有子女,如果有则递归调用家谱建立函数建立子女结点,并将其赋给配偶结点的下一个右结点。

5:

如无,则程序结束

首先判断当前结点是否为空,如果为空则结束程序;

如果不为空,则输出当前结点信息,

然后判断其左结点(配偶结点)是否为空,如不为空则输出“和配偶信息。

再判断配偶结点的右结点是否为空,如不为空则递归调用输出其子女信息,最后输出“)”;

当配偶结点为空时,则判断其右结点(兄弟结点)是否为空

6:

如果不为空,则输出“,”,并递归调用输出兄弟信息

7程序结束

当前结点是否为空,为空则返回空;

如果和查找信息相同,则返回当前结点;

如不然,则先后递归访问其左结点,再不是则递归访问右结点

在家谱中定位到要查找的结点,如无则输出“查找不到此人”

判断其配偶结点与子女结点是否为空,为空则输出“无子女”

不为空则输出其配偶结点的所有右结点(子女结点)。

先在家谱中定位到要查找的结点,如为空输出“不存在此人”,程序结束

先将父母结点入栈,当栈为空时程序结束,

栈不为空时,判断栈顶元素是否已访问过,

访问过,再判断是否为查找结点,如是则输出栈中保存的其祖先结点,并滤过其兄弟结点不输出;

不是查找结点,则退栈一个元素

未访问过,则取当前栈顶元素,置访问标志――1,同时取其右结点

栈不为空或当前所取结点不为空时,转到2;

实验测试结果及结果分析

(一)测试结果

(二)结果分析

(略)

实验总结

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 成人教育 > 电大

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1