- 18.50 KB
- 4页
- 1、本文档共5页,可阅读全部内容。
- 2、本文档内容版权归属内容提供方,所产生的收益全部归内容提供方所有。如果您对本文有版权争议,可选择认领,认领后既往收益都归您。
- 3、本文档由用户上传,本站不保证质量和数量令人满意,可能有诸多瑕疵,付费之前,请仔细先通过免费阅读内容等途径辨别内容交易风险。如存在严重挂羊头卖狗肉之情形,可联系本站下载客服投诉处理。
- 文档侵权举报电话:19940600175。
'数据结构项目报告项目题目:三元组项目成员:日期: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.项目总结与思考完成这个项目,让我发现自己很容易犯一些小错误,例如用一个指针表示它所指向的值,容易丢失*,通过这项目让我了解二级指针的使用。源程序如下:#include#include#include#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(i<1||i>3)returnERROR;*e=T[i-1];returnOK;}StatusPut(TripletT,inti,ElemTypee){if(i<1||i>3)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("%dn",e);Put(A,2,4);printf("%dn",A[1]);t=IsAscending(A);
printf("%dn",t);k=IsDescending(A);printf("%dn",k);Max(A,&j);printf("%dn",j);Min(A,&i);printf("%dn",i);DestroyTriplet(&A);return0;}'
您可能关注的文档
- 装备制造业项目报告.doc
- ANSYS轧辊接触和弯曲分析项目报告.doc
- 浙江生物质成型燃料项目报告.doc
- JavaWeb项目报告模板.doc
- 皖维集团IT规划项目报告.ppt
- 智能家居系统项目报告(第五组).doc
- 桁架机器人项目报告.docx
- 项目报告1:交通灯故障报警电路.doc
- 一阶倒立摆项目报告.doc
- 精益项目报告(改善模板).ppt
- 临朐县鸿浩装饰工程有限公司年磷化处理1500吨金属件项目报告表.pdf
- 众泰Z300上市前实车测试项目报告.ppt
- 扎赉特旗大维矿业有限责任公司石灰岩矿年产30万吨矿石开采改扩建项目报告书.pdf
- 深圳燃气集团分布式能源项目报告(终稿).ppt
- 大学工程经济学三级项目报告书模拟样本.pdf
- 瑜伽工作室项目报告bd.pdf
- 精益项目报告模板课件.ppt
- QCC项目报告―印象圈课件.ppt