




已阅读5页,还剩6页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
数学与计算科学学院实 验 报 告实验项目名称 线性表的链式表示 所属课程名称 数据结构(C语言版) 实 验 类 型 验证型实验 实 验 日 期 2011年10月28日 班 级 信计1001班 学 号 201053100127 姓 名 成 绩 一、实验概述:【实验目的】1.掌握线性链表的逻辑结构特征:总存在第一个和最后一个元素;除第一个元素以外,每个元素总存在唯一一个直接前驱元素;除最后一个元素以外,每个元素总存在唯一一个直接后继元素。2.线性链表的特点:逻辑结构上相邻物理结构上不相邻;是一种随机的存储结构。3.通过上机实验验证顺序表的算法正确性,了解算法与程序的区别。【实验原理】线性链表的存储结构:用一组任意的存储单元存储线性表的数据元素.【实验环境】VC+6.0二、实验内容:【实验方案】首先建立一个带表头节点的单链线性表,然后调用输入函数给每个节点赋值,然后调用插入和删除函数插入和删除元素。【实验过程】(实验步骤、记录、数据、分析)在输入窗口输入:#include#include#define TRUE 1#define FALSE 0#define OK 1 #define ERROR 0#define INFEASIBLE -1#define OVERFLOW -2typedef int Status;typedef int ElemType;typedef struct LNode ElemType data; struct LNode *next;LNode, *LinkList;Status GetElem_L(LinkList L,int i,ElemType&e)p=L-next;j=1;while(p&jnext;+j;if(!p|ji)return ERROR;e=p-data;return OK;Status ListInsert_L(LinkList &L,int i,ElemType e)p=L;j=0;while(p&jnext;+j;if(!p|ji-1) return ERROR;s=(LinkList)malloc(sizeof(LNode);s-data=e;s-next=p-next;p-next=s;return OK;Status ListDelete_L(LinkList &L,int i,ElemType &e)p=Lj=0;while(p-next&jnext;+j;if(!(p-next)|ji-1) return ERROR;q=p-next;p-next=q-next;e=q-data;free(q);return OK;void CreateList_L(LinkList &L,int n)L=(LinkList)malloc(sizeof(LNode);L-next=NULL;for(i=n;i0;-i)p=(LinkList)malloc(sizeof(LNode);scanf(&(p-data);p-next=L-next;L-next=p;void main() LinkList L;int i=5; LinkList p; CreateList_L(L,i); for(p=L-next;p;p=p-next) printf(%d ,p-data); printf(n); int e; scanf(%d,&i); GetElem_L(L,i,e); printf(%d,e);printf(n); scanf(%d %d,&i,&e); ListInsert_L(L,i,e); for(p=L-next;p;p=p-next) printf(%d ,p-data); printf(n); scanf(%d,&i); ListDelete_L(L,i,e); printf(%d,e); printf(n); for(p=L-next;p;p=p-next) printf(%d ,p-data); 然后进行调试,调试过程如下:1. c:documents and settingsxpclient桌面教学软件专区123.cpp(18) : error C2065: p : undeclared identifier改正方法:在p=L-next;前加LinkList p;2.C:Documents and SettingsXPCLIENT桌面教学软件专区123.cpp(20) : error C2065: j : undeclared identifier改正方法:在j=0前加int j;2. C:Documents and SettingsXPCLIENT桌面教学软件专区123.cpp(35) : error C2065: p : undeclared identifier改正方法:在p=L前加LinkList p;3. C:Documents and SettingsXPCLIENT桌面教学软件专区123.cpp(37) : error C2065: j : undeclared identifier改正方法:在j=0前加int j;4. C:Documents and SettingsXPCLIENT桌面教学软件专区123.cpp(47) : error C2065: s : undeclared identifier改正方法:将LinkList p;改成LinkList p,s;5. C:Documents and SettingsXPCLIENT桌面教学软件专区123.cpp(56) : error C2065: p : undeclared identifier改正方法:在p=L前加LinkList p;6. C:Documents and SettingsXPCLIENT桌面教学软件专区123.cpp(58) : error C2065: j : undeclared identifier改正方法:在j=0前加int j;7. C:Documents and SettingsXPCLIENT桌面教学软件专区123.cpp(67) : error C2065: q : undeclared identifier改正方法:将LinkList p;改成LinkList p,q;8. C:Documents and SettingsXPCLIENT桌面教学软件专区123.cpp(78) : error C2065: i : undeclared identifier改正方法:在L=(LinkList)malloc(sizeof(LNode);前加int i;9. C:Documents and SettingsXPCLIENT桌面教学软件专区123.cpp(77) : error C2146: syntax error : missing ; before identifier L改正方法:在int i;加LinkList p;10. C:Documents and SettingsXPCLIENT桌面教学软件专区123.cpp(83) : error C2664: scanf : cannot convert parameter 1 from int * to const char *改正方法:将scanf(&(p-data);改成scanf(%d,&(p-data);此时窗口显示:123.obj - 0 error(s), 0 warning(s)调试完毕。再运行窗口输入,得到实验结果:【实验结论】(结果)【实验小结】(收获体会)通过此次试验,熟悉掌握了线性表的逻辑结构特征和线性链表的特点,对于程序的调试和程序中错误的纠正有了更深一层的掌握,受益匪浅!三、指导教师评语及成绩:评 语评语等级优良中及格不及格1.实验报告按时完成,字迹清楚,文字叙述流畅,逻辑性强2.实验方案设计合理3.实验过程(实验步骤详细,记录完整,数据合理,分析透彻)4实验结论正确. 成 绩: 指导教师签名: 批阅日期:附录1:源 程 序#include#include#define OK 1 #define ERROR 0typedef int Status;typedef int ElemType;typedef struct LNode ElemType data; struct LNode *next;LNode, *LinkList;void CreateList_L(LinkList &L,int n) int i; LinkList p; L=(LinkList)malloc(sizeof(LNode); L-next=NULL; for(i=n;i0;-i) p=(LinkList)malloc(sizeof(LNode); scanf(%d,&p-data); p-next=L-next;L-next=p; Status GetElem_L(LinkList L,int i,ElemType &e) LinkList p; int j; p=L-next;j=1; while(p&jnext;+j; if(!p|ji)return ERROR; e=p-data; return OK;Status ListInsert_L(LinkList &L,int i,ElemType e) LinkList p,s; int j; p=L; j=0; while(p-next&jnext;+j; if(!p|ji-1)return ERROR;s=(LinkList)malloc(sizeof(LNode);s-data=e;s-next=p-next;p-next=s;return OK;Status ListDelete_L(LinkList &L,int i,ElemType &e)LinkList p,q;int j; p=L;j=0; while(p-next&jnext;+j; if(!(p-next)|ji-1)return ERROR; q=p-next;p-next=q-next; e=q-data;free(q); return OK;void main() LinkList L;int i; LinkList p; printf(请输入要建立的空表的节点数i=); scanf(%d,&i);printf(请输入数据:); CreateList_L(L,i); for(p=L-next;p;p=p-next) printf(%d ,p-data); printf(n); int e; printf(请输入要输出的节点数:); scanf(%d,&i); GetElem_L(L,i,e); printf(%d,e);printf(n); printf(请输入要插入的节点数:); scanf(%d %d,&i,&e); ListInsert_L(L,i,e); for(p=L-next;p;p=p-next) printf(%d ,p-data); printf(n); printf(请输入要删除的节点数:); scanf(%d,&i); ListDelete_L(L,i,e); printf(%d,e); printf(n); for(p=L-next;p;p=p-next) printf(%d ,p-data); 附录2:实验报告填写说明 1实验项目名称:要求与实验教学大纲一致。2实验目的:目的要明确,要抓住重点,符合实验教学大纲要求。3实验原理:简要说明本实验项目所涉及的理论知识。4实验环境:实验用的软、硬件环境。5实验方案(思路、步骤和方法等):这是实验报告极其重要的内容。概括整个实验过程。对于验证性实验,
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 智能制造财务担保合同
- 保险单质押贷款业务保险理赔跟踪合作协议
- 矿区土地承包开发投资合作协议书
- 基础设施财务代理与运营管理协议
- 餐饮外卖平台合作协议书
- 住宅区拆迁补偿安置协议书(含房屋分配方案)
- 汽车抵押贷款反欺诈合同
- 车辆抵押贷款转全款购车及贷款利率调整合同
- 企业分红与财产分配协议
- 体育场馆场地租赁及赛事运营管理合作协议
- GB/T 26354-2025旅游信息咨询服务
- 【日化智云】2024年家居清洁品类市场概况及2025年消费者洞察新品趋势报告
- 新疆维吾尔自治区2024年普通高校招生单列类(选考外语)本科一批次投档情况(文史)
- 麻醉科理论知识培训课件
- 课题申报书:数字化升级背景下婴幼儿托育服务与管理专业“五金”建设实践研究
- 江苏省南京市2024年中考物理试卷(含答案)
- 湖南省2025年八年级下学期中考模拟生物试题(BEST联考)(含答案)
- 拉萨市“一考三评”学习考试题库
- 委托收款协议书模板
- 《工业网络与组态技术》课程标准
- 一年级学生元角分练习500题
评论
0/150
提交评论