经典数据结构上机题―答案.doc

经典数据结构上机题―答案.doc

ID:55594784

大小:106.00 KB

页数:26页

时间:2020-05-19

经典数据结构上机题―答案.doc_第1页
经典数据结构上机题―答案.doc_第2页
经典数据结构上机题―答案.doc_第3页
经典数据结构上机题―答案.doc_第4页
经典数据结构上机题―答案.doc_第5页
资源描述:

《经典数据结构上机题―答案.doc》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、数据结构上机实验题目实验一线性表的顺序存储结构实验学时2学时背景知识:顺序表的插入、删除及应用。目的要求:1.掌握顺序存储结构的特点。2.掌握顺序存储结构的常见算法。实验内容1.输入一组整型元素序列,建立顺序表。2.实现该顺序表的遍历。3.在该顺序表中进行顺序查找某一元素,查找成功返回1,否则返回0。4.判断该顺序表中元素是否对称,对称返回1,否则返回0。5.实现把该表中所有奇数排在偶数之前,即表的前面为奇数,后面为偶数。6.输入整型元素序列利用有序表插入算法建立一个有序表。7.利用算法6建立两个非递减有序表并把它们合并成一个非递减有序表。8.利用该顺序结构实现循环队列的入队、出队操

2、作。8.编写一个主函数,调试上述算法。#include#include#defineOVERFLOW0#defineMAXSIZE100typedefintElemType;typedefstructlist{ElemTypeelem[MAXSIZE];intlength;}Sqlist;voidCreatlist(Sqlist&L){inti;printf("请输入顺序表的长度:");//输入一组整型元素序列,建立一个顺序表。scanf("%d",&L.length);for(i=0;i

3、lem[i]);}voidprintlist(Sqlist&L)//以输出的形式实现对该顺序表的遍历{inti;for(i=0;i

4、");}voidInseri(Sqlist&L,inti,intx)//在顺序表的第i个位置上插入一个元素x{intj;for(j=L.length;j>=i;j--)L.elem[j]=L.elem[j-1];L.elem[j]=x;L.length++;}voidDelete(Sqlist&L,inti)//删除顺序表中第i个元素{intj;for(j=i;j

5、(L.length==MAXSIZE)exit(OVERFLOW);//表满,不能插入for(i=1;i<=L.length&&L.elem[i-1]<=x;i++);for(j=L.length;j>=i;j--)L.elem[j]=L.elem[j-1];L.elem[i-1]=x;L.length++;}voidCreatlist_sorted(Sqlist&L)//利用有序表插入算法建立一个有序表{inti,num;ElemTypex;L.length=0;printf("请输入顺序表的长度:");scanf("%d",&num);for(i=1;i<=num;i++){sc

6、anf("%d",&x);Insert(L,x);}}voidMerger(Sqlist&p,Sqlist&r,Sqlist&c)//建立两个非递减有序表,并把它们合并成一个非递减有序表{ElemType*a,*b,i=0,j=0,k=0;a=&p.elem[0];b=&r.elem[0];c.length=p.length+r.length;while(i=*b){c.elem[k]=*b;b++;k++;j++;}else{c.elem[k]=*a;a++;k++;i++;}}if(j==r.length)for(;k

7、.length;k++){c.elem[k]=*a;a++;}elseif(i==p.length)for(;k

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。