欢迎来到冰点文库! | 帮助中心 分享价值,成长自我!
冰点文库
全部分类
  • 临时分类>
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • ImageVerifierCode 换一换
    首页 冰点文库 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    北京邮电大学数据结构实验第一次实验线性表.docx

    • 资源ID:17307123       资源大小:103.88KB        全文页数:17页
    • 资源格式: DOCX        下载积分:3金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    北京邮电大学数据结构实验第一次实验线性表.docx

    1、北京邮电大学数据结构实验第一次实验线性表数据结构实验报告实验名称: 实验1线性表学生姓名:班 级: 班内序号: 学 号: 日 期: 1实验要求根据线性表的抽象数据类型的定义,选择下面任一种链式结构实现线性表,并完成线性表的基本功能。 线性表存储结构(五选一): 1、 带头结点的单链表 2、 不带头结点的单链表 3、 循环链表 4、 双链表 5、 静态链表 线性表的基本功能: 1、 构造:使用头插法、尾插法两种方法 2、 插入:要求建立的链表按照关键字从小到大有序 3、 删除 4、 查找 5、 获取链表长度 6、 销毁 7、 其他:可自行定义 编写测试main()函数测试线性表的正确性。2.程序

    2、分析 2.1 存储结构 2.2 关键算法分析1:头插法 自然语言描述: a:在堆中建立新结点 b:将ai写入到新结点的数据域 c:修改新结点的指针域 d:修改头结点的指针域。将新结点加入链表中 伪代码描述 a:Node * s=new Node b:s-data=ai c:s-next=front-next; d:front-next=s 2:尾插法 自然语言描述: a:在堆中建立新结点: b:将ai写入到新结点的数据域: c:将新结点加入到链表中 d:修改修改尾指针 伪代码描述 a:Node * s=new Node b:s-data=ai c:r-next=s; d:r=s 3:析构/删除

    3、函数 自然语言描述: a:新建立一个指针,指向头结点 b:判断要释放的结点是否存在, c:暂时保存要释放的结点 d:移动a中建立的指针 e:释放要释放的指针 伪代码描述 a:Node * p=front b:while(p) c:front=p d:p=p-next e:delete front4:按位查找函数 自然语言描述: a:初始化工作指针p和计数器j,p指向第一个结点,j=1 b:循环以下操作,直到p为空或者j等于1 b1:p指向下一个结点 b2:j加1 c:若p为空,说明第i个元素不存在,抛出异常 d:否则,说明p指向的元素就是所查找的元素,返回元素地址 伪代码描述 a:Node *

    4、 p=front-next;j=1; b:while(p&j!=1) b1:p=p-next b2:j+ c:if(!p) throw -1 d:return p 5:按值查找函数 自然语言描述: a:初始化工作指针p和计数器j,p指向第一个结点,j=1 b:循环以下操作,找到这个元素或者p指向最后一个结点 c:判断p指向的结点是不是要查找的值,如果是,返回j,否则p指向下一个结点,并且j的值加一 d:如果找到最后一个结点还没有找到要查找的元素,返回查找失败信息 伪代码描述 a:Node * p=front-next;j=1; b:while(p) c:if(p-next=x) return

    5、j p=p-next j+ d:return -1 6:插入函数 自然语言描述: a:在堆中建立新结点 b:将要插入的结点的数据写入到新结点的数据域 c:修改新结点的指针域 d:修改前一个指针的指针域,使其指向新插入的结点的位置 伪代码描述 a:Node * s=new Node ; b:s-data=p-data c:s-next=p-next d:p-next=s e:p-data=x7:删除函数 自然语言描述: a:从第一个结点开始,查找要删除的位数i前一个位置i-1的结点 b:设q指向第i个元素 c:将q元素从链表中删除 d:保存q元素的数据 e:释放q元素 伪代码描述 a:q=p-n

    6、ext b:p-next=q-next c:x=q-data d:delete q 8:遍历打印函数 自然语言描述: a:判断该链表是否为空链表,如果是,报错 b:如果不是空链表,新建立一个temp指针 c:将temp指针指向头结点 d:打印temp指针的data域 e:逐个往后移动temp指针,直到temp指针的指向的指针的next域为空 伪代码描述 If front-next=NULL Throw ”an empty list ” Node* temp=front-next; while(temp-next) coutdatanext; 8:获取链表长度函数 自然语言描述: a:判断该链表

    7、是否为空链表,如果是,输出长度0 b:如果不是空链表,新建立一个temp指针,初始化整形数n为0 c:将temp指针指向头结点 d:判断temp指针指向的结点的next域是否为空,如果不是,n加一,否则return n e: 使temp指针逐个后移,重复d操作,直到temp指针指向的结点的next域为0,返回n伪代码描述 int n=0 if front-next=NULL n=0 else Node* temp=front-next; while(temp-next) n+; temp=temp-next; return n; 1:头插法插入链表 Node *s =new Node ; s-

    8、data=ai; s-next=front-next; front-next=s; 2:尾插法插入链表 Node *s=new Node ; s-data=ai; r-next=s; r=s; 3:查找算法 Node*p=front-next; int j=1; while(p&j!=i) p=p-next; j+; 4:删除算法 Node*p=front; if(i!=1)p=Get(i-1); Node*q=p-next; p-next=q-next; T x=q-data; delete q; 头插法/尾插法 O(n) 按位查找/按值查找 O(n) 插入操作 O(n)3. 程序运行结果截

    9、图流程图 开始 初始化对象 初始化整形数组 利用头插法和尾插法初始化,用遍历打印函数来显示数值 执行删除函数,然后用遍历打印函数来检测删除结果 执行插入函数,然后用遍历打印函数来检测插入结果 按位查找和按值查找 结束4. 总结 对链表的掌握不够扎实,对类的掌握不全面。代码:#includeusing namespace std;class Nodepublic: int data; Node*next;class LinkListpublic: LinkList() ; LinkList(int a,int n); Node * Get(int j); int Locate(int x); v

    10、oid Insert(int j,int x); int Delete(int j); int Getlength(); void Print(); LinkList();private: Node* front; int length;LinkList:LinkList(int a,int n) front = new Node; front - next = NULL; for(int j=n-1;j=0;j-) Node*s=new Node; s-data=aj; s-next=front-next; front-next=s; /*LinkList:LinkList(int a,in

    11、t n) front = new Node; Node*r=front; for(int j=0;jn;j+) Node*s=new Node; s-data=aj; s-next=s; r=s; r-next=NULL;*/Node*LinkList:Get(int i) Node*p=front-next; int j =1; while(p&j!=i) p=p-next; j+; return p;int LinkList:Locate(int x) Node*p=front-next; int j=1; while(p) if(p-data=x) return j; p=p-next;

    12、 j+; return -888;void LinkList:Insert(int i,int x) Node*p=front; if(i!=1) p=Get(i-1); if(p) Node* s=new Node; s-data=x; s-next=p-next; p-next=s; else throw error;int LinkList:Delete(int i) Node*p=front; if(i!=1) p=Get(i-1); Node*q=p-next; p-next=q-next; int x=q-data; delete q; return x;LinkList:Link

    13、List() Node*p = front; while(p) front = p; p=p-next; delete front; int LinkList:Getlength() length = 0; Node * n = front-next; while(NULL != n) length+; n = n-next; return length;void LinkList:Print() Node*n=front-next; while(NULL!=n) coutdatanext; coutendl;void main() int a10=7,9,10,11,22,8,33,2,21,80; LinkList*Lin=new LinkList(a,10); coutGetlength()endl; coutGet(7)endl; coutGet(100)endl; coutLocate(9)endl; coutLocate(50)Print(); Lin-Insert(3,20); Lin-Print(); Lin-Delete(5); Lin-Print(); Lin-LinkList; Lin-Print();


    注意事项

    本文(北京邮电大学数据结构实验第一次实验线性表.docx)为本站会员主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 冰点文库 网站版权所有

    经营许可证编号:鄂ICP备19020893号-2


    收起
    展开