数据的逻辑结构PPT学习教案_第1页
数据的逻辑结构PPT学习教案_第2页
数据的逻辑结构PPT学习教案_第3页
数据的逻辑结构PPT学习教案_第4页
数据的逻辑结构PPT学习教案_第5页
已阅读5页,还剩34页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、会计学1 数据的逻辑结构数据的逻辑结构 2 第1页/共39页 第2页/共39页 ni aaaa , ,21 如 例 英文字母表(A,B,C,.Z)是一个线性表 例 学号姓名年龄 001张三18 002李四19 数据元素 元素文件 n特征: 元素个数n表长度,n=0空表 1idata表示p指向结点的数据域 (*p).nextp-next表示p指向结点的指针域 生成一个LNode型新结点:p=(LNode *)malloc(sizeof(LNode); 系统回收p结点:free(p) n线性链表 定义:结点中只含一个指针域的链表叫,也叫单链表 第20页/共39页 ha1a2 头结点 an . h

2、空表 头结点:在单链表第一个结点前附设一个结点叫 头结点指针域为空表示线性表为空 第21页/共39页 时间复杂度 T(n) = O(n) Status GetElem_L(LinkList j = 1; / 初始化,p指向第一个结点,j为计数器 while (p +j; if ( !p | ji ) return ERROR; / 第i个元素不存在 e = p-data; / 取第i个元素 return OK; / GetElem_L 第22页/共39页 24 pab xs 插入:在线性表两个数据元素a和b间插入x, 已知p指向a s-next=p-next; p-next=s; P30 算法

3、 2.9 时间复杂度 T(n) = O(n) 第23页/共39页 Status ListDelete_L(LinkList j = 0; while (p-next +j; if (!(p-next) | j i-1) return ERROR; / 删除位置不合理 q = p-next; p-next = q-next; / 删除并释放结点 e = q-data; free(q); return OK; / ListDelete_L pabc 时间复杂度 T(n) = O(n) 删除:单链表中删除b,设p指向a p-next=p-next-next; 第24页/共39页 h 头结点 an 0

4、h 头结点 an-10an a2 .h 头结点 an-10an ha1a2 头结点 an .0 h 头结点 0 nOnT 动态建立单链表算法:设线性表n个元素已存放在数组a中,建立一个单链表,h为头指针 nCreateList_L P30 算法 2.11 算法评价 第25页/共39页 27 合并有序链表MergeList_L P31 算法 2.12 void MergeList_L(LinkList pb = Lb-next; Lc = pc = La; / 用La的头结点作为Lc的头结点 while (pa pc = pa; pa = pa-next; else pc-next = pb;

5、pc = pb; pb = pb-next; pc-next = pa ? pa : pb; / 插入剩余段 free(Lb); / 释放Lb的头结点 / MergeList_L 算法2.2 的两种实现:算法2.7 顺序,算法2.12 链接 第26页/共39页 静态链表 无指针类型语言 BASIC 大数组 用游标(指示器cur)代替指针 P32 图2.10 备用链表:未使用的分量(数组元素) P33 例2-3 (A-B)U(B-A) 算法2.14-2.17 图2.11 数组静态链表1 备用链表 0 第27页/共39页 h h 空表 尾指针 合并简化 P35 图2.13 temp = B-nex

6、t; B-next = A-next; A-next = temp- next; A = B;第28页/共39页 typedef struct DulNode ElemType data; struct DulNode *prior,*next; DulNode, *DulLinkList; priorelement next L 空双向循环链表: 非空双向循环链表: LAB bca p p-prior-next= p= p-next-proir; 第29页/共39页 bca P 删除 P37 算法2.19 ListDelete_DuL 算法评价:T(n)=O(n) p-prior-next=

7、p-next; p-next-prior=p-prior; 第30页/共39页 32 第31页/共39页 ListInsert_DuL 1. s-prior = p-prior; 2. p-prior-next = s; 3. s-next = p; 4. p-prior = s; x S ba P 插入 第32页/共39页 34 算法评价:T(n)=O(n) 小结:带头结点的线性链表 取消参数i 位序 算法改写 算法2.20 2.21 第33页/共39页 n nn xPxPxPPxP 2 210 )( ),( 210n PPPPP 可用线性表P表示 200001000 231)(xxxS但对

8、S(x)这样的多项式浪费空间 一般 em mn xPxPxPxP ee 21 21 )( 其中 为非零系数)( i Pemee210 用数据域含两个数据项的线性表表示 emPePeP m, ,21 21 其存储结构可以用顺序存储结构,也可以用单链表 第34页/共39页 typedef struct node int coef,exp; struct node *next; JD; coefexp next 177 87 178 522117)()()( 9228)( 5937)( xxxxBxAxC xxxxB xxxxA -1 A 7 0 3 1 9 8 5 17 -1 B 8 1 22 7

9、 -9 8 -1 C 7 0 11 1 22 7 5 17 n一元多项式相加 第35页/共39页 设p,q分别指向A,B中某一结点,p,q初值是第一结点 比较 p-exp与q-exp p-exp exp: p结点是和多项式中的一项 p后移,q不动 p-exp q-exp: q结点是和多项式中的一项 将q插在p之前,q后移,p不动 p-exp = q-exp: 系数相加 0:从A表中删去p, 释放p,q,p,q后移 0:修改p系数域, 释放q,p,q后移 直到p或q为NULL 若q=NULL,结束 若p=NULL,将B中剩余部分连到A上即可 n运算规则 第36页/共39页 q -1 pa 7 0 3 1 9 8 5 17 -1 pb 8 1 22 7 -9 8 p pre q -1 pa 7 0 3 1 9 8 5 17 -1 pb 8 1 22 7 -9 8 ppre q -1 pa 7 0 11 1 9 8 5 17 -1 pb 8 1 22 7 -9 8 p pr e q -1 pa 7 0 11 1 9 8 5 17 -1 pb 8 1 22 7 -9 8 p pre q=NULL -1 pa 7 0 11 1 9 8 5 17 -1

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论