1 / 11
文档名称:

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

格式:doc   大小:131KB   页数:11页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

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

上传人:xgs758698 2019/5/24 文件大小:131 KB

下载得到文件列表

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

相关文档

文档介绍

文档介绍:实验名称:实验1——线性表学生姓名:班级:班内序号:学号:日期:实验要求1、实验目的:熟悉C++语言的基本编程方法,掌握集成编译环境的调试方法学****指针、模板类、异常处理的使用掌握线性表的操作的实现方法学****使用线性表解决实际问题的能力2、实验内容:题目1:线性表的基本功能:构造:使用头插法、尾插法两种方法插入:要求建立的链表按照关键字从小到大有序删除查找获取链表长度销毁其他:可自行定义编写测试main()函数测试线性表的正确性。、伪代码实现:在堆中建立新结点将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、伪代码实现:[i]、代码实现:Linklist::Linklist(inta[],intn,intm)//尾插法{front=newNode;Node*r=front;for(inti=0;i<n;i++){Node*s=newNode;s->data=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指向的元素就是所查找的元素,返回元素地址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*p=front->next;if(!p)//如果链表为空,直接插入{Node*s=newNode;s->data=x;s->next=front->next;front->next=s;}elsewhile(!((p->next->data>x)&&(p->data<x)))//判断p的下一个结点的值大于x且p的值小于x{p=p->next;}Node*s=newNode;//将x插入到p之后s->data=x;s->next=p->next;p->next=s;}5、删除操作a、伪代码实现:从第一个结点开始,查找要删除的位数i前一个位置i-1的结点设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指针,直到temp指针的指向的指针的next域为空b、代码实现voidLinklist::show()//打印数组元素{Node*p=front->next;while(p){cout<<p->data<<"";p=p->next;}}、伪代码实现:判断该链表是否为空链表,如果是,输出长度0如果不是空链表,新建立一个temp指针,初始化整形数n为0将temp指针指向头结点判断temp指针指向的结点的next域是否为空,如果不是,n加一,否则returnn使temp指针逐个后移,重复d操作,直到temp指针指向的结点的next域为0,返回nb、代码实现voidLinklist::Getlength()//得到数组长度{Node*p=front->next;intj=0;while(p){