数据结构实验报告表达式求值

时间:2019-05-12 03:57:25下载本文作者:会员上传
简介:写写帮文库小编为你整理了多篇相关的《数据结构实验报告表达式求值》,但愿对你工作学习有帮助,当然你在写写帮文库还可以找到更多《数据结构实验报告表达式求值》。

第一篇:数据结构实验报告表达式求值

数据结构实验报告

题目:

编制一个表达式求值的程序。

一. 需求分析

1.本演示程序中,利用堆栈存储结构存储读入的运算符,输入的限定范围是数字(0—9),以及+*/()。输入字符串限定长度为20,可以根据需要进行改变。如果遇到不是以上范围或者连续输入两个运算符,如:++,则会提示输入错误,请重新输入。输出的结果是转换后的后序表达式,以及float型数字,不会含有非法字符。

2.演示程序采用的是文件输入,只需要在源代码中输入要输入的文件的地址,然后就可以在文本文件中进行输入,运行过程中会自动读取,输出文本输入的表达式,及运算结果。3.程序执行的命令包括:

1)构造字符优先级比较表,比较优先关系 2)文件输入 3)构造堆栈,运算符入栈 4)堆栈输出,变为后序表达式,并计算 5)输出结果,结束 4.测试数据

文件地址:C:UserslenovoDesktop4.txt

1)输入:(35+20/2)*2-4/2+12 正确输出结果是:100.0000 2)输入:(35+20/2)*2-/2+12 结果是:error input

3)输入:a+ar/3=135 结果是:error input

二.概要设计

为实现以上程序功能,需运用堆栈用于存储运算符,因此需要定义抽象数据类型。1.堆栈的抽象数据类型定义为: ADT stack{

数据对象:D={ai|ai∈正整数,i=0,1,2,3,…n,及{+-*/()}} 数据关系:R1={|ai-1,ai∈D} 基本操作: Init stack(&s)

操作结果:构造一个空的堆栈s Push stack(&s, e)初始条件:存在堆栈s 操作结果:元素e压入堆栈s,top+1 Pop(&s,e)

初始条件:栈s已经存在且非空

操作结果:删除栈顶元素e,输出其值,top-1 2.程序包含三个模块: 1)运算符优先关系模块 2)主程序模块;Int main(void){ 初始化; Do{

接受命令; 处理命令; }while(“命令”=”退出”); } 3)堆栈模块

三.详细设计

1.程序源代码解释为:

float Result(int c,float r[],int top){

//定义输出结果

int j;

float temp;

switch(c){

//以下是四种基本运算的计算定义,运算完成后直接将top-1值赋予top

case 42:r[top-1]=r[top-1]*r[top];top=top-1;break;

//乘法

case 43:r[top-1]=r[top-1]+r[top];top=top-1;break;///加法

case 45:r[top-1]=r[top-1]-r[top];top=top-1;break;//减法

case 47:r[top-1]=r[top-1]/r[top];top=top-1;break;// 除法

case 94:for(j=1,temp=r[top-1];j

temp=r[top-1]*temp;

//循环相乘

r[top-1]=temp;

top=top-1;

break;

}

return(r[top]);}

if(temp1!=1){ while(top>=1){

//栈不空的时候,栈中元素赋给houzhi,并计数

biaozhi[b++]=i;

houzhi[i]=duizhan[top-1];

top=top-1;i=i+1;

} max=i;

//从0到i循环输出后序表达式 for(i=0,b=0;i

if(i!=biaozhi[b])printf(“%d ”,houzhi[i]);

//输出后序表达式中的数字

else {

printf(“%c ”,houzhi[i]);

//输出后序表达式中的运算符

b=b+1;

}

}

top=-1;for(i=0,b=0;i

//从0到max

if(i!=biaozhi[b]){

top=top+1;

result[top]=houzhi[i];

//将后值赋予result,调用result函数,进行Result运算

}

else {Result(houzhi[i],result,top);

//运算结束,输出栈顶值,既是运算结果

top--;

b=b+1;

}

}

printf(“nnThe result is %f ”,Result(houzhi[i],result,top));

//输出并打印结果

} } getch();return 0;///返回0 } 2.程序的模块调用:

主程序 ↓

文件打开读入字符

输入字符有效及优先级的判断

↓ 运算模块 ↓ 输出结果

四.调试分析

1.本次作业的核心就是利用堆栈将中序表达式改成后序表达式,然后进行表达式的求值。具体思想就是当读入数字时,直接输出。当读入运算符时如果不是后括号,直接将其进栈,顺序比较读入的运算符与栈顶元素的优先级(栈不空),如果栈顶元素的优先级高,则直接将其出栈并输出。遇到后括号直接输出栈中元素,直到遇到前括号。

2.算法的思想不是很复杂,在编程中只是加入了运算符的优先级比较表。以及如何获得优先级的大小关系。起初在开始编制运算符优先级比较时,完全没有想法,最后在网上学 习了一下,终于学会了如何建立比较表,通过练习也加深了对堆栈的掌握。总的过程还是可以的。

3.本题中也就只使用一堆栈存储运算符,空间复杂度O与输入的表达式中的运算符的多少有关,所以空间复杂度为O(n)(其实要小一点),对于时间复杂度而言,不仅要

考虑读入表达式的时间,还要考虑优先级的比较,进出栈,虽然比较多比较复杂,但是应该也是T(n)的数量级。

4.只是在WIN—TC下编译运行了程序,并把直接运行时输入改为了由文本文档文件输入,在进行改编的过程中,由于关闭文件的指针放的位置不对,还导致了输出结果始终是0,通过改变指针的位置最终完成了文件输入的改编。

五.心得体会

在本次实验中,我负责表达式的输出程序的编程,编写了一个result函数来进行结果输出。编程中遇到了很多困难,我们三个人也进行了很多次的讨论,遇到无法解决的困难,则寻求其他大学同学的帮助。在商讨算法的过程中,放弃了二叉树的思想,改用堆栈的方式。由于我们大一学过C语言,其函数调用简单方便,并且编写小的程序非常方便,所以选择了WIN-TC。

六.源代码

#include “Stdio.h” #include “ctype.h” int find(char x){

int i;

char a[7]=“+-*/^()”;

for(i=0;;i++)

if(a[i]!=x&&i<7)continue;

else if(i<7)return(i+1);

else return(0);

}

char Compare(char c1,char c2){

char relat[7][7]={{'>','>','<','<','<','<','>'},{'>','>','<','<','<','<','>'},{'>','>','>','>','<','<','>'},{'>','>','>','>','<','<','>'},{'>','>','>','>','>','<','>'},{'<','<','<','<','<','<','='},{'>','>','>','>','>',' ','>'}};

return(relat[find(c1)-1][find(c2)-1]);

}

float Result(int c,float r[],int top){

int j;

float temp;

switch(c){

case 42:r[top-1]=r[top-1]*r[top];top=top-1;break;

case 43:r[top-1]=r[top-1]+r[top];top=top-1;break;

case 45:r[top-1]=r[top-1]-r[top];top=top-1;break;

case 47:r[top-1]=r[top-1]/r[top];top=top-1;break;

case 94:for(j=1,temp=r[top-1];j

temp=r[top-1]*temp;

r[top-1]=temp;

top=top-1;

break;

}

return(r[top]);}

int transe(char c[],int len){

int sum=0,i,j,temp;

for(i=0;i

for(j=0,temp=1;j

temp=temp*10;

sum=sum+(c[i]-'0')*temp;

}

return(sum);}

Int main(void){ char s[20],duizhan[20],temp[10];

float result[10];int houzhi[20]={0},biaozhi[10]={0};int i=0,j=0,m=0,top=0,b=0,done,n,temp1=0,cont,max;

FILE* fp = fopen(“C:UserslenovoDesktop4.txt”, “r”);

if(fp==NULL){printf(“cannot open filen”);

exit(0);} fscanf(fp, “%s”, s);

printf(“%sn”,s);

n=strlen(s);

for(j=0;j

if(!isdigit(s[j])&&!isdigit(s[j+1])&&s[j]!='('&&s[j+1]!='('&&s[j]!=')'&&s[j+1]!=')')

printf(“Eeeor input!nPress any key to continue!”);

else continue;

done=2;

}

if(done!=2){ for(j=0;j

if(isdigit(s[j])){

m=0;cont=1;

temp[m++]=s[j++];

done=0;

while(isdigit(s[j])&&j

temp[m++]=s[j++];

done=1;

cont++;

}

if(done==1)

houzhi[i++]=transe(temp,cont);

else houzhi[i++]=s[j-1]-'0';

}

else if(find(s[j])!=7&&(find(s[j])!=0))

{

if(top==0)duizhan[top++]=s[j++];

else{

done=0;

while(done==0){

switch(Compare(duizhan[top-1],s[j])){

case '<':duizhan[top]=s[j];

top=top+1;j++;

done=1;

break;

case '=':biaozhi[b++]=i;

houzhi[i]=duizhan[top-1];

top=top-1;

if(top==0){duizhan[top]=s[j];

top=top+1;j++;

done=1;

}

i=i+1;

break;

case '>':biaozhi[b++]=i;

houzhi[i]=duizhan[top-1];

top=top-1;

if(top==0){duizhan[top]=s[j];

top=top+1;j++;

done=1;

}

i=i+1;

break;

}

}

}

}

else if(find(s[j])==7){

while(duizhan[top-1]!='('){

biaozhi[b++]=i;

top=top-1;

houzhi[i]=duizhan[top];

i=i+1;

}

top=top-1;

j++;

}

else {

printf(“Eeeor input!nPress any key to continue!”);

temp1=1;

break;

} } if(temp1!=1){ while(top>=1){

biaozhi[b++]=i;

houzhi[i]=duizhan[top-1];

top=top-1;i=i+1;

} max=i;

for(i=0,b=0;i

if(i!=biaozhi[b])printf(“%d ”,houzhi[i]);

else {

printf(“%c ”,houzhi[i]);

b=b+1;

}

} top=-1;for(i=0,b=0;i

if(i!=biaozhi[b]){

top=top+1;

result[top]=houzhi[i];

}

else {Result(houzhi[i],result,top);

top--;

b=b+1;

}

}

printf(“nnThe result is %f ”,Result(houzhi[i],result,top));

} } getch();return 0;}

1.本程序的运行环境是WIN—TC,也可以是DOS操作系统,执行文件是***.exe。

2.文件的输入直接是通过文本文档,或其他,直接在源代码中输入打开文件的地址,然后操作均在文本中进行,比较方便。界面如下: 源代码中地址输入:

运行中界面:

七.测试结果

1.输入正确的表达式:(24/2+12-4/2)+25/5*2

2.输入:(32+1/3+14)*2+3^2/2

3.输入字母,非法字符:ad+12xg

4.输入连续的运算符:23++12

第二篇:数据结构实验报告

注意:实验结束后提交一份实验报告电子文档

电子文档命名为“学号+姓名”,如:E01214058宋思怡

《数据结构》实验报告

(一)学号:姓名:专业年级:

实验名称:线性表

实验日期:2014年4月14日

实验目的:

1、熟悉线性表的定义及其顺序和链式存储结构;

2、熟练掌握线性表在顺序存储结构上实现基本操作的方法;

3、熟练掌握在各种链表结构中实现线性表基本操作的方法;

4、掌握用 C/C++语言调试程序的基本方法。

实验内容:

一、编写程序实现顺序表的各种基本运算,并在此基础上设计一个主程序完成如下功能:

(1)初始化顺序表L;

(2)依次在L尾部插入元素-1,21,13,24,8;

(3)输出顺序表L;

(4)输出顺序表L长度;

(5)判断顺序表L是否为空;

(6)输出顺序表L的第3个元素;

(7)输出元素24的位置;

(8)在L的第4个元素前插入元素0;

(9)输出顺序表L;

(10)删除L的第5个元素;

(11)输出顺序表L。

源代码

调试分析(给出运行结果界面)

二、编写程序实现单链表的各种基本运算,并在此基础上设计一个主程序完成如下功能:

„„„„

„„„„

小结或讨论:

(1)实验中遇到的问题和解决方法

(2)实验中没有解决的问题

(3)体会和提高

第三篇:数据结构实验报告

南京信息工程大学实验(实习)报告

实验(实习)名称数据结构实验(实习)日期 2011-11-2得分指导教师周素萍

系公共管理系专业信息管理与信息系统年级10级班次1姓名常玲学号2010230700

3实验一顺序表的基本操作及C语言实现

【实验目的】

1、顺序表的基本操作及 C 语言实现

【实验要求】

1、用 C 语言建立自己的线性表结构的程序库,实现顺序表的基本操作。

2、对线性表表示的集合,集合数据由用户从键盘输入(数据类型为整型),建立相应的顺序表,且使得数据按从小到大的顺序存放,将两个集合的并的结果存储在一个新的线性表集合中,并输出。

【实验内容】

1、根据教材定义的顺序表机构,用 C 语言实现顺序表结构的创建、插入、删除、查找等操作;

2、利用上述顺序表操作实现如下程序:建立两个顺序表表示的集合(集合中无重

复的元素),并求这样的两个集合的并。

【实验结果】

[实验数据、结果、遇到的问题及解决]

一. Status InsertOrderList(SqList &va,ElemType x)

{

}

二. Status DeleteK(SqList &a,int i,int k)

{//在非递减的顺序表va中插入元素x并使其仍成为顺序表的算法 int i;if(va.length==va.listsize)return(OVERFLOW);for(i=va.length;i>0,x

}

//注意i的编号从0开始 int j;if(i<0||i>a.length-1||k<0||k>a.length-i)return INFEASIBLE;for(j=0;j<=k;j++)a.elem[j+i]=a.elem[j+i+k];a.length=a.length-k;return OK;

三.// 将合并逆置后的结果放在C表中,并删除B表

Status ListMergeOppose_L(LinkList &A,LinkList &B,LinkList &C)

{

LinkList pa,pb,qa,qb;pa=A;pb=B;qa=pa;qb=pb;// 保存pa的前驱指针 // 保存pb的前驱指针 pa=pa->next;pb=pb->next;A->next=NULL;C=A;while(pa&&pb){} while(pa){} qa=pa;pa=pa->next;qa->next=A->next;A->next=qa;if(pa->data

data){} else{} qb=pb;pb=pb->next;qb->next=A->next;//将当前最小结点插入A表表头 A->next=qb;qa=pa;pa=pa->next;qa->next=A->next;//将当前最小结点插入A表表头 A->next=qa;

}

} pb=B;free(pb);return OK;qb=pb;pb=pb->next;qb->next=A->next;A->next=qb;

顺序表就是把线性表的元素存储在数组中,元素之间的关系直接通过相邻元素的位置来表达。

优点:简单,数据元素的提取速度快;

缺点:(1)静态存储,无法预知问题规模的大小,可能空间不足,或浪费存储空间;(2)插入元素和删除元素时间复杂度高——O(n)

求两个集合的并集

该算法是求两个集合s1和s2的并集,并将结果存入s引用参数所表示的集合中带回。首先把s1集合复制到s中,然后把s2中的每个元素依次插入到集合s中,当然重复的元素不应该被插入,最后在s中就得到了s1和s2的并集,也就是在s所对应的实际参数集合中得到并集。

第四篇:数据结构实验报告

数据结构实验报告

一. 题目要求

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

//数据域

InsertBST(bst,a[i]);

i++;} returnbst;} int Delete(BiTree&T)

{

BiTreeq,s;

} if(!(T)->rChild){ //右子树为空重接它的左子树

q=T;T=(T)->lChild;free(q);}else{

if(!(T)->lChild){ //若左子树空则重新接它的右子树

q=T;T=(T)->rChild;}else{ q=T;s=(T)->lChild;while(s->rChild){

q=s;s=s->rChild;}

(T)->data=s->data;//s指向被删除结点的前驱

if(q!=T)

q->rChild=s->lChild;

else

q->lChild=s->lChild;

free(s);} } return 1;

//删除函数,在T中删除key元素 intDeleteBST(BiTree&T,int key){ if(!T)return 0;else{

if(key==(T)->data)return Delete(T);

else{

if(key<(T)->data)

returnDeleteBST(T->lChild,key);

else

returnDeleteBST(T->rChild,key);

} } } intPosttreeDepth(BiTree T){//求深度

inthr,hl,max;if(!T==NULL){ hl=PosttreeDepth(T->lChild);hr=PosttreeDepth(T->rChild);max=hl>hr?hl:hr;return max+1;} else

return 0;

} void printtree(BiTreeT,intnlayer){//打印二叉树 if(T==NULL)return;printtree(T->rChild,nlayer+1);for(inti=0;i

”);} printf(“%dn”,T->data);printtree(T->lChild,nlayer+1);} void PreOrderNoRec(BiTree root)//先序非递归遍历 { BiTree p=root;BiTreestack[50];intnum=0;while(NULL!=p||num>0){

while(NULL!=p)

{

printf(“%d ”,p->data);

stack[num++]=p;

p=p->lChild;

}

num--;

p=stack[num];

p=p->rChild;} printf(“n”);} void InOrderNoRec(BiTree root)//中序非递归遍历 { BiTree p=root;

} intnum=0;BiTreestack[50];while(NULL!=p||num>0){ while(NULL!=p){

stack[num++]=p;

p=p->lChild;} num--;p=stack[num];printf(“%d ”,p->data);p=p->rChild;} printf(“n”);void PostOrderNoRec(BiTree root)//后序非递归遍历 { BiTree p=root;BiTreestack[50];intnum=0;BiTreehave_visited=NULL;

while(NULL!=p||num>0){

while(NULL!=p)

{

stack[num++]=p;

p=p->lChild;

}

p=stack[num-1];

if(NULL==p->rChild||have_visited==p->rChild)

{

printf(“%d ”,p->data);

num--;

have_visited=p;

p=NULL;

}

else

{

p=p->rChild;

} } printf(“n”);}

int main(){//主函数

printf(“

---------------------二叉排序树的实现-------------------”);printf(“n”);int layer;inti;intnum;printf(“输入节点个数:”);scanf(“%d”,&num);printf(“依次输入这些整数(要不相等)”);int *arr=(int*)malloc(num*sizeof(int));for(i=0;i

scanf(“%d”,arr+i);} BiTreebst=CreateBST(arr,num);printf(“n”);printf(“二叉树创建成功!”);printf(“n”);layer=PosttreeDepth(bst);printf(“树状图为:n”);printtree(bst,layer);int j;int T;int K;for(;;){ loop: printf(“n”);printf(“

***********************按提示输入操作符************************:”);printf(“n”);printf(“

1:插入节点

2:删除节点

3:打印二叉树

4:非递归遍历二叉树

5:退出”);scanf(“%d”,&j);

switch(j){

case 1:

printf(“输入要插入的节点:”);

scanf(“%d”,&T);

InsertBST(bst,T);

printf(“插入成功!”);printf(“树状图为:n”);

printtree(bst,layer);

break;

case 2:

}

printf(“输入要删除的节点”);scanf(“%d”,&K);DeleteBST(bst,K);printf(“删除成功!”);printf(“树状图为:n”);printtree(bst,layer);break;case 3: layer=PosttreeDepth(bst);printtree(bst,layer);break;case 4:

printf(“非递归遍历二叉树”);printf(“先序遍历:n”);PreOrderNoRec(bst);printf(“中序遍历:n”);InOrderNoRec(bst);

printf(“后序遍历:n”);

PostOrderNoRec(bst);

printf(“树状图为:n”);

printtree(bst,layer);

break;case 5:

printf(“程序执行完毕!”);

return 0;} goto loop;} return 0;对于第四小问,要储存学生的三个信息,需要把上面程序修改一下,二叉树结构变为 typedefintElemType;

//数据类型 typedefstring SlemType;

typedefint Status;

//返回值类型 //定义二叉树结构 typedefstructBiTNode{ SlemType name;ElemType score;ElemType no;

//数据域 structBiTNode *lChild, *rChild;//左右子树域 }BiTNode, *BiTree;参数不是key,而是另外三个

intInsertBST(BiTree&T,intno,intscore,string name){//插入二叉树函数

if(T==NULL){

T =(BiTree)malloc(sizeof(BiTNode));

T->no=no;T->name=name;T->score=score;

T->lChild=T->rChild=NULL;

return 1;} else if(nono){ InsertBST(T->lChild,no,score,name);} else if(key>T->data){

InsertBST(T->rChild,no,score,name);} else

return 0;} 其他含参函数也类似 即可完成50个信息存储

用数组存储50个信息,查看以往代码

#include #include using namespace std;class student{ private: intnum;string name;int ob1;int ob2;intara;public: void set(inta,stringb,intc,int d);void show();int average();};void student ::set(inta,stringb,intc,int d){ num=a;name=b;ob1=c;ob2=d;ara=(c+d)/2;} void student::show(){ cout<<“学号:”<

int main(){ cout<<“ 欢迎来到学生管理系统”<>numlock;switch(numlock){ case 0: cout<<“输入想查询的学号”<>i;if(i==j){ cout<<“该学号信息已被删除”<>j;delete[j]ptr;cout<<“删除成功”<>k;if(k!=j){

cout<<“该学号信息已经存在,添加失败”<

break;} cout<<“重新输入添加的学号”<>q;cout<<“输入姓名”<>w;cout<<“输入科目一的成绩”<>e;cout<<“输入科目二的成绩”<>r;ptr[k].set(q,w,e,r);break;case 3: for(m=1;m<20;m++){

for(int n=m+1;n<20;n++){

if(ptr[m].average()

student a;

a=ptr[m];

ptr[m]=ptr[n];

ptr[n]=a;

}}

ptr[m].show();} break;case 4: cout<<“谢谢使用”<

二叉排序树储存数据界面(储存学生信息略)

创建二叉树:

插入节点:

删除节点:

非递归遍历:

退出:

数组储存学生信息界面

分析查找效率:

因为二叉树查找要创建二叉树,而数组查找只创建一个数组,二叉树的创建时间比较长,所以对于数据量较少的情况下数组的查找效率比较高。但当数据量增加时,二叉树的查找优势就显现出来。所以数据量越大的时候,二叉树的查找效率越高。

四. 总结与改进

这个实验工作量还是很大的,做了很久。树状图形输出还是不美观,还需要改进。

一开始打算用栈实现非递归,但是根据书里面的伪代码发现部分是在C++编译器里运行不了的(即使补充了头文件和数据的定义),所以之后参考了网上的数组非递归,发现其功能和栈相似。

递归遍历的实现比非递归的遍历真的简单很多。

开始时只看到前三问,所以没有写到储存学生数据的代码,里面还可以用clock()函数加一个计算查找所要数据时间的代码,让二叉树查找与数组查找到效率比较更加直观。

第五篇:数据结构实验报告

实验报告4 排序

一、实验目的

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

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

3、了解各种方法的排序过程及其依据的原则,并掌握各种排序方法的时间复杂度的分析方法。

二、实验要求及内容

要求编写的程序所能实现的功能包括:

1、从键盘输入要排序的一组元素的总个数

2、从键盘依次输入要排序的元素值

3、对输入的元素进行快速排序

4、对输入的元素进行折半插入排序

三、实验代码及相关注释

#include using namespace std;#include “malloc.h”

typedef struct { int key;}RedType;

typedef struct { RedType r[100];int length;}SqList;

//1 快速排序的结构体

typedef struct {

int data[100];

int last;}Sequenlist;//2 折半插入排序的结构体

int Partition(SqList &L, int low, int high)

//1 寻找基准

{

L.r[0]=L.r[low];//子表的第一个记录作基准对象

int pivotkey = L.r[low].key;//基准对象关键字 while(low

while(low= pivotkey)--high;

L.r[low] = L.r[high];//小于基准对象的移到区间的左侧

while(low

L.r[high] = L.r[low];//大于基准对象的移到区间的右侧 }

L.r[low] = L.r[0];return low;}

void QuickSort(SqList &L, int low, int high)

//1 快速排序 { //在序列low-high中递归地进行快速排序

if(low < high)

{

int pivotloc= Partition(L, low, high);

//寻找基准

QuickSort(L, low, pivotloc-1);//对左序列同样递归处理

QuickSort(L, pivotloc+1, high);//对右序列同样递归处理

} }

Sequenlist *Sqlset()

//2 输入要折半插入排序的一组元素

{

Sequenlist *L;

int i;

L=(Sequenlist *)malloc(sizeof(Sequenlist));

L->last=0;

cout<<“请输入要排序的所有元素的总个数:”;

cin>>i;

cout<

cout<<“请依次输入所有元素的值:”;

if(i>0)

{

for(L->last=1;L->last<=i;L->last++)

cin>>L->data[L->last];

L->last--;

}

return(L);}

middlesort(Sequenlist *L)

//2 折半插入排序 { int i,j,low,high,mid;for(i=1;i<=L->last;i++){

L->data[0]=L->data[i];

low=1;

high=i-1;

while(low<=high)

{

mid=(low+high)/2;

if(L->data[0]data[mid])

high=mid-1;//插入点在前半区

else

low=mid+1;//插入点在后半区

}

for(j=i;j>high+1;j--){ L->data[j]=L->data[j-1];} //后移

L->data[high+1]=L->data[0];//插入 } return 0;}

int main(){ gg: cout<<“请选择功能(1.快速排序 2.折半插入排序 3.退出程序):”;int m;cin>>m;cout<

if(m==1){ SqList L;int n;cout<<“请输入要排序的所有元素的总个数:”;cin>>n;cout<

cin>>L.r[i].key;

} cout<

QuickSort(L,1,L.length);

for(int j=1;j<=L.length;j++)

{

cout<

}

cout<

cout<

}

if(m==2){

Sequenlist *L;

int i;

L=Sqlset();

cout<

middlesort(L);

cout<<“折半插入排序后为:”;

for(i=1;i<=L->last;i++)

{

cout<data[i]<<“ ”;

}

cout<

cout<

goto gg;}

if(m==3){

exit(0);

cout<

四、重要函数功能说明

1、Sequenlist *Sqlset()

输入要折半插入排序的一组元素

2、int Partition(SqList &L, int low, int high)

寻找快速排序的基准

3、void QuickSort(SqList &L, int low, int high)

快速排序

4、middlesort(Sequenlist *L)

折半插入排序

五、程序运行结果

下图仅为分别排序一次,可多次排序,后面有相关截图:

六、实验中遇到的问题、解决及体会

1、起初编写快速排序的程序时,我是完全按照老师PPT上的算法敲上去的,然后建立了一个SqList的结构体,调试运行时出现错误,仔细查看才意识到Partition函数中L中应该包含元素key,而我建立结构体时没有注意,然后我将key这个元素补充进去,继续调试,又出现错误,提示我Partition没有定义,我就觉得很奇怪,我明明已经写了函数定义,为什么会这样,当我又回过头来阅读程序时,我发现QuickSort函数中调用了Partition函数,但是我的Partition函数的定义在QuickSort函数的后面,于是我将Partition函数放到了QuickSort函数的前面,再次调试运行,就可以正常运行,得出结果了。这让我懂得,编程一定要认真仔细,不可大意马虎,否则又会花很多时间回过头来检查修改程序,得不偿失。

运行程序错误截图:

2、本来我是编写了两个程序,分别实现快速排序和折半插入排序的功能,但我后来想我是否可以将其合二为一,于是我想到用if选择语句用来实现不同的功能,从键盘输入功能选项m,if(m==1),可以进行快速排序,if(m==2),可以进行折半插入排序,于是我继续思考,我是否可以在一次运行程序中,多次对含有不同元素的序列进行排序,于是我用了goto语句,每次排序一次后,自动循环到选择语句,当不需要在排序的时候,可以从键盘输入3,退出程序,这样一来,程序变得更加实用和清晰明朗。这让我懂得,想要编出好的程序,要善于思考,在实现所需功能的前提下,多想问题,看是否能使程序更加实用简便。

修改程序前两个运行结果截图

(两个程序,调试运行两次,每次只能进行一次排序)

1、快速排序程序运行结果截图:

2、折半插入排序程序结果截图:

程序重要模块修改截图:

修改程序后运行截图:

(一个程序,调试运行一次,可多次进行不同序列的不同排序)

下载数据结构实验报告表达式求值word格式文档
下载数据结构实验报告表达式求值.doc
将本文档下载到自己电脑,方便修改和收藏,请勿使用迅雷等下载。
点此处下载文档

文档为doc格式


声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:645879355@qq.com 进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。

相关范文推荐

    数据结构实验报告

    数 据 结 构 实 验 报 告 1.问题描述 为某个单位建立一个员工通讯录管理系统,可以方便地查询每一个员工的办公室电话号码、手机号码及电子邮箱。 2. 设计分析 在本设计中,整......

    数据结构实验报告

    数据结构实验报告 第一次实验 学号:20141060106 姓名:叶佳伟 一、实验目的 1、复习变量、数据类型、语句、函数; 2、掌握函数的参数和值; 3、了解递归。 二、实验内容 1、(必做......

    数据结构实验报告

    天 津 科 技 大 学 14学年—15学年第 2 学期 数据结构实验任务书 专业名称: 计算机科学与技术 实验学时: 4 课程名称:数据结构 任课教师: 史绍强 实验题目:图的最短路径算法的实......

    数据结构实验报告

    河南省高等教育自学考试 实 验 报 告 册 计算机及应用专业(本科段) 《数据结构》姓名周东伟准考证号010512201008所属地市郑州实验地点河南职业技术学院实验日期2014-3-18实验......

    数据结构实验报告

    数据结构实验报告 指导教师 姓 名班 级学 号实验 室 黄梅根钟志伟 0140703 07310325 S331-B 2008-11-29 单链表的插入和删除实验日志 指导教师:黄梅根实验时间:2008年10月1......

    数据结构实验报告

    数据结构实验报告 实验名称数据结构与算法专业班级 数学与应用数学1201班 学号 1304120306 姓名谢 伟 指导老师陈 明......

    数据结构实验报告

    浙江师范大学 实 验 报 告 学 院: 数理与信息工程学院 专 业: 计算机科学与技术 姓 名: 杨富生 学 号: 201531910137 课程名称: 数据结构 指导教师: 钟发荣 实验时间: 2016-06-15......

    数据结构查找实验报告

    实验题9.1 设计一个程序exp9-1.cpp,输出在顺序表{3,6,2,10,1,8,5,7,4,9}中采用顺序方法找关键字5的过程。 程序如下: //文件名:exp9-1.cpp #include #define MAXL 100 typedef int Ke......