



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实验报告要求一、 实验目的二、 实验内容三、 程序流程图四、 实验结果(要求检测所有情况的正确性,写出测试条件及相应的测试结果)五、 完成思考题实验一 顺序表的基本操作(2学时)一、实验目的了解顺序表的逻辑特征,掌握顺序表的描述方法、特点及有关的概念,掌握顺序表上的插入和删除等基本操作算法。二、实验内容在顺序表List 中,实现顺序表的基本操作,包括:初始化顺序表,在表中插入元素、删除元素。基本要求:(1) 顺序表的元素个数可随意设定;(2) 可连续测试任意多个元素的插入、删除,(插入、删除位置及要插入元素数值均从键盘输入);(3) 任一操作结束后将顺序表中的内容输出;(4) 可由用户选择退出程序。三、实验要点及说明顺序表又称为线性表的顺序存储结构,它是用一组地址连续的存储单元依次存放线性表的各个元素。 可按如下格式定义顺序表: #define MAXLEN 50 /* 定义顺序表最大元素个数50 */ typedef structdatatype ListMAXLEN; /* 定义顺序表List */ int Num; /* 定义顺序表表长*/Seqlist;模块划分:(1)initiq( )函数:初始化顺序表 (2)insertq( )函数:实现插入功能 (3)deleteq( )函数:实现删除功能 (4)print( )函数:实现输出功能四、参考源程序#include #define MAXLEN 50typedef int datatype;typedef struct datatype ListMAXLEN; int Num; Seqlist;void initiq(Seqlist *la );int insertq(Seqlist *la,int n);int deleteq(Seqlist *la,int n);int print(Seqlist *la);void main() Seqlist la;int s,n; /* s 选择输入, n 插入或删除数据的个数*/printf(请输入你的选择: 1-initiate 2-insert 3-delete 4-print 5-exitnyour choice =);scanf(%d,&s);while(s!=5) if(s=1) initiq( &la );printf(完成初始化 !n); else if(s=2) printf(请输入待插入的数据个数:);scanf(%d,&n); insertq(&la,n);print(&la); else if(s=3) printf(请输入待删除的数据个数:);scanf(%d,&n);deleteq(&la,n);print(&la); else if(s=4) print(&la); else printf(你的选择是错误的!n );printf(请输入你的选择: 1-initiate 2-insert 3-delete 4-print 5-exitnyour choice =);scanf(%d,&s); /*初始化*/void initiq(Seqlist *la ) la- Num=0; /*插入*/int insertq(Seqlist *la,int n) int i,j; /* i 插入位置, j 顺序表下标 */datatype x; /* x 插入数据 */while(n) if (la-Num=MAXLEN-1) printf (n 表满,不能插入!插入未完成,还有%d个数据未插入n,n);return 0; printf(请输入插入的位置和数据:);scanf(%d%d,&i,&x);if (ila-Num) printf (n 插入位置不合理!n); else if (i= la-Num)la-Listi=x;else for ( j=la-Num; ji; j-)la-Listj=la-Listj-1;la-Listi=x; la-Num+;n-; printf(插入完成n);return 1; /*删除*/int deleteq(Seqlist *la,int n) int i,j; /* i 删除位置, j 顺序表下标 */while(n) if (la-Num=0) printf (n 表空,不能删除!n);return 0; printf(请输入删除的位置:);scanf(%d,&i);if (i=la-Num) printf (n 删除位置错误!n); else for ( j=i+1; jNum; j+)la-Listj-1=la-Listj;la-Num-;n-; printf(删除完成!n);return 1; /*显示输出*/int print (Seqlist *la) int m;if (la-Num=0) printf(顺序表为空!n);return 0; else printf(当前的顺序表为:n);for(m=0;mNum;m+)printf(List%d=%d ,m,la-Listm);printf(n表长为%dn,la-Num);return 1; 五、思考题1设顺序表L中的数据元素按递增排列,编写一个算法,将数据元素x插入到顺序表L的适当位置上,以保持顺序表的有序性。2设计一算法实现删除顺序表a中第i个元素起的k个元素。typedef struct i
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 云南省潞西市芒市高中政治 3.6.2 博大精深的中华文化说课稿 新人教版必修3
- 2025年教育信息化基础设施建设与教育信息化人才培养报告
- 第十四课 正视压力轻松迎考教学设计高中心理健康北师大版2015高中三年级全一册-北师大版2015
- 四、插入特殊符号说课稿小学信息技术粤教版B版三年级下册-粤教版(B版)
- 2025年中国高迁移率半导体材料行业市场分析及投资价值评估前景预测报告
- 跨学科主题学习-向世界介绍我的学校教学设计初中信息科技电子工业版2022第二册七年级下-电子工业版2022
- 2023四年级数学上册 1 大数的认识第5课时 将整万数改写成用“万”作单位的数说课稿 新人教版
- 2025年中国高端油漆保护膜行业市场分析及投资价值评估前景预测报告
- Unit 5 What were you doing when the rainstorm came SectionA 1a-1c 教学设计2023-2024学年人教版八年级英语下册
- 实习生知识培训课件
- 学校对外交流与合作的机会拓展
- 2025年春季形势与政策-从教育大国迈向教育强国
- 人教部编版七年级上册第三单元名著导读《朝花夕拾》复习考点
- 人教版高二上学期数学(选择性必修1)《第一章空间向量与立体几何》单元测试卷及答案
- 第四章-运动系统
- 九上历史知识点总结(表格版)
- 范更华-图论及其应用
- 店长分成合作协议书
- 家乡文化渠县
- 2024年自考00055《企业会计学》历年真题及答案整理版
- 信息技术与小学语文阅读教学深度融合的策略研究
评论
0/150
提交评论