数据结构三元组项目报告

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

数据结构项目报告项目题目:三元组项目成员:日期:2012年4月1号1.题目与要求1.1问题提出详细叙述本项目所要实现的问题是创建一个三元组并且实现一些有关三元组的操作。1.2本项目涉及的知识点指针,数值,函数的调用1.3功能要求1创建一个三元组并且给它们赋值。2如果三元组存在,把三元组释放并且赋空。3根据给的一个位置,来找出三元组里面这个位置的值并且返回。4判断三元组里面的值是否按递增排列.5判断三元组里面的值是否按递减排列。6求三元组里面数值的最大值.7求三元组里面数值的最小值。8根据给的一个位置,改变三元组这个位置的值。2.功能设计2.1总体设计运用函数调用的方式将整个程序连接起来,使其变得完整,具体见代码。2.2详细设计本程序可分八个小模块。第1个小模块实现创建一个三元组并且给它们赋值;第2个小模块实现如果三元组存在,把三元组释放并且赋空;第3个小模块实现根据给的一个位置,来找出三元组里面这个位置的值并且返回;第个4小模块实现判断三元组里面的值是否按递增排列;第5个小模块实现判断三元组里面的值是否按递减排列;第个6小模块实现求三元组里面数值的最大值;第7个小模块实现求三元组里面数值的最小值;第8个小模块实现根据给的一个位置,改变三元组这个位置的值。模块一:创建一个三元组并且给它们赋值,函数为StatusInitTriplet(Triplet*T,ElemTypev1,ElemTypev2,ElemTypev3)T是个整形二级指针,v1,v2,v3整形变量,通过(ElemType*)malloc(3*sizeof(ElemType))申请一个连续的空间给(*T),然后v1,v2,v3的值分别赋给它们。模块二:如果三元组存在,把三元组释放并且赋空,函数为StatusDestroyTriplet(Triplet*T)T是个整形二级指针,如果(*T)存在,则通过free()把它释放并且把它赋空。模块三:根据给的一个位置,来找出三元组里面这个位置的值并且返回,函数为StatusGet(TripletT,inti,ElemType*e)T是个整形二级指针,整形i表示那个位置,*e表示要返回i位置的值,把(*T)【i-1】赋给*e。模块四:判断三元组里面的值是否按递增排列,函数为StatusIsAscending(TripletT)T是个整形二级指针,判断它们一个是否比一个大。模块五:判断三元组里面的值是否按递减排列,函数为StatusIsDescending(TripletT)T是个整形二级指针,判断它们一个是否比一个小。模块六:求三元组里面数值的最大值,函数为StatusMax(TripletT,ElemType*e)T是个整形二级指针,*e是用来返回最大的值,通过一个一个的比较来实现模块七:求三元组里面数值的最小值,函数为StatusMin(TripletT,ElemType*e)T是个整形二级指针,*e是用来返回最小的值,通过一个一个的比较来实现模块八:根据给的一个位置,改变三元组这个位置的值,函数为StatusPut(TripletT,inti,ElemTypee)T是个整形二级指针,整形i表示那个位置,*e表示要赋值给i位置的值,把*e赋给(*T)【i-1】。3.项目总结与思考完成这个项目,让我发现自己很容易犯一些小错误,例如用一个指针表示它所指向的值,容易丢失*,通过这项目让我了解二级指针的使用。源程序如下:#includestdio.h#includemalloc.h#includeprocess.h#defineOVERFLOW-2#defineOK1#defineERROR0typedefintStatus;typedefintElemType;typedefint*Triplet;StatusInitTriplet(Triplet*T,ElemTypev1,ElemTypev2,ElemTypev3){(*T)=(ElemType*)malloc(3*sizeof(ElemType));if(!(*T))exit(OVERFLOW);(*T)[0]=v1;(*T)[1]=v2;(*T)[2]=v3;returnOK;}StatusDestroyTriplet(Triplet*T){free((*T));(*T)=NULL;returnOK;}StatusGet(TripletT,inti,ElemType*e){if(i1||i3)returnERROR;*e=T[i-1];returnOK;}StatusPut(TripletT,inti,ElemTypee){if(i1||i3)returnERROR;T[i-1]=e;returnOK;}StatusIsAscending(TripletT){return(T[0]=T[1])&&(T[1]=T[2]);}StatusIsDescending(TripletT){return(T[0]=T[1])&&(T[1]=T[2]);}StatusMax(TripletT,ElemType*e){*e=(T[0]=T[1])?((T[0]=T[2])?T[0]:T[2]):((T[1]=T[2])?T[1]:T[2]);returnOK;}StatusMin(TripletT,ElemType*e){*e=(T[0]=T[1])?((T[0]=T[2])?T[0]:T[2]):((T[1]=T[2])?T[1]:T[2]);returnOK;}intmain(){TripletA;ElemTypee,t,k,j,i;InitTriplet(&A,1,2,3);Get(A,2,&e);printf(%d\n,e);Put(A,2,4);printf(%d\n,A[1]);t=IsAscending(A);printf(%d\n,t);k=IsDescending(A);printf(%d\n,k);Max(A,&j);printf(%d\n,j);Min(A,&i);printf(%d\n,i);DestroyTriplet(&A);return0;}

1 / 4
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功