数据结构实验一题目一线性表实验报告.doc

数据结构实验一题目一线性表实验报告.doc

ID:56773391

大小:127.00 KB

页数:10页

时间:2020-07-08

数据结构实验一题目一线性表实验报告.doc_第1页
数据结构实验一题目一线性表实验报告.doc_第2页
数据结构实验一题目一线性表实验报告.doc_第3页
数据结构实验一题目一线性表实验报告.doc_第4页
数据结构实验一题目一线性表实验报告.doc_第5页
资源描述:

《数据结构实验一题目一线性表实验报告.doc》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、数据结构实验报告实验名称:实验1——线性表学生姓名:班级:班内序号:学号:日期:1.实验要求1、实验目的:熟悉C++语言的基本编程方法,掌握集成编译环境的调试方法学习指针、模板类、异常处理的使用掌握线性表的操作的实现方法学习使用线性表解决实际问题的能力2、实验内容:题目1:线性表的基本功能:1、构造:使用头插法、尾插法两种方法2、插入:要求建立的链表按照关键字从小到大有序3、删除4、查找5、获取链表长度6、销毁7、其他:可自行定义编写测试main()函数测试线性表的正确性。2.程序分析2.1存储结构带头结点的单链表2.2关键算法分析1.头插法a、伪代码

2、实现:在堆中建立新结点将x写入到新结点的数据域修改新结点的指针域修改头结点的指针域,将新结点加入链表中b、代码实现:Linklist::Linklist(inta[],intn)//头插法{front=newNode;front->next=NULL;for(inti=n-1;i>=0;i--){Node*s=newNode;s->data=a[i];s->next=front->next;front->next=s;}}2、尾插法a、伪代码实现:a.在堆中建立新结点b.将a[i]写入到新结点的数据域c.将新结点加入到链表中d.修改修改尾指针b、代码实

3、现:Linklist::Linklist(inta[],intn,intm)//尾插法{front=newNode;Node*r=front;for(inti=0;idata=a[i];r->next=s;r=s;}r->next=NULL;}时间复杂度:O(n)3、按位查找a、伪代码实现:初始化工作指针p和计数器j,p指向第一个结点,j=1循环以下操作,直到p为空或者j等于1b1:p指向下一个结点b2:j加1若p为空,说明第i个元素不存在,抛出异常否则,说明p指向的元素就是所查找的元素,返回元素地址

4、b、代码实现Node*Linklist::Get(inti)//得到指向第i个数的指针{Node*p=front->next;intj=1;while(p&&j!=i)//p非空且j不等于i,指针后移{p=p->next;j++;}returnp;}4、插入操作a、伪代码实现:如果链表为空,直接插入判断p的下一个结点的值大于x且p的值小于x在堆中建立新结点将要插入的结点的数据写入到新结点的数据域修改新结点的指针域修改前一个指针的指针域,使其指向新插入的结点的位置b、代码实现voidLinklist::Insert(intx)//将x按顺序插入{Node

5、*p=front->next;if(!p)//如果链表为空,直接插入{Node*s=newNode;s->data=x;s->next=front->next;front->next=s;}elsewhile(!((p->next->data>x)&&(p->datanext;}Node*s=newNode;//将x插入到p之后s->data=x;s->next=p->next;p->next=s;}5、删除操作a、伪代码实现:从第一个结点开始,查找要删除的位数i前一个位置i-1的结点

6、设q指向第i个元素将q元素从链表中删除保存q元素的数据释放q元素b、代码实现intLinklist::Delete(inti)//删除第i个位置的结点{Node*p=front;if(i!=1)p=Get(i-1);//得到第i-1个位置的指针Node*q=p->next;p->next=q->next;intx=q->data;deleteq;returnx;}6遍历打印函数a、伪代码实现:判断该链表是否为空链表,如果是,报错如果不是空链表,新建立一个temp指针将temp指针指向头结点打印temp指针的data域逐个往后移动temp指针,直到tem

7、p指针的指向的指针的next域为空b、代码实现voidLinklist::show()//打印数组元素{Node*p=front->next;while(p){cout<data<<"";p=p->next;}}7.获取链表长度函数a、伪代码实现:判断该链表是否为空链表,如果是,输出长度0如果不是空链表,新建立一个temp指针,初始化整形数n为0将temp指针指向头结点判断temp指针指向的结点的next域是否为空,如果不是,n加一,否则returnn使temp指针逐个后移,重复d操作,直到temp指针指向的结点的next域为0,返回nb、代码

8、实现voidLinklist::Getlength()//得到数组长度{Node*p=fron

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

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

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