




已阅读5页,还剩87页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1,2.4 一元多项式的表示及相加,第二章 线性表,2.1 线性表的类型定义,2.2 线性表的顺序表示和实现,2.3 线性表的链式表示和实现,2,学习提要: 1.了解线性表的逻辑结构和存储结构。 2.掌握两种存储结构的描述方法以及在每种存储结构上的基本操作的实现。 3.理解两种存储结构的特点及其使用场合。重难点内容: 顺序表、链表及其操作实现,3,线性结构的基本特征:,线性结构是一个数据元素的 有序(次序)集 。,1集合中必存在唯一的一个“第一元素”;,2集合中必存在唯一的一个 “最后元素” ;,3除最后元素在外,均有 唯一的后继;,4除第一元素之外,均有 唯一的前驱。,2.1 线性表的类型定义,4,线性表:n个数据元素组成的有限序列。 表示为(a1,a2,ai,ai+1,an),例:英文字母表(A,B,C,.Z)是一个线性表,5,线性表的长度:表中元素的个数n(n=0),n=0 空表。位序:元素ai在表中的位置数i 。,逻辑特征:1in时ai的直接前驱是ai-1,a1无直接前驱ai的直接后继是ai+1,an无直接后继元素同构,且不能出现缺项,6,抽象数据类型线性表的定义如下:,ADT List ,数据对象:,D ai | ai ElemSet, i=1,2,.,n, n0 ,数据关系:,R1 |ai-1 ,aiD, i=2,.,n ,7,基本操作:,结构初始化操作,结构销毁操作,引用型操作,加工型操作, ADT List,8,InitList( &L ),操作结果:,构造一个空的线性表L。,初始化操作:,结构销毁操作:,DestroyList( &L ),初始条件:操作结果:,销毁线性表 L。,线性表 L 已存在。,9,ListEmpty( L ),ListLength( L ),PriorElem( L, cur_e, &pre_e ),NextElem( L, cur_e, &next_e ),GetElem( L, i, &e ),LocateElem( L, e, compare( ) ),ListTraverse(L, visit( ),引用型操作:,10,ListEmpty( L ),初始条件:操作结果:,线性表L已存在。,若L为空表,则返回TRUE,否则FALSE。,(线性表判空),ListLength( L ),初始条件:操作结果:,线性表L已存在。,返回L中元素个数。,(求线性表的长度),11,PriorElem( L, cur_e, &pre_e ),初始条件:操作结果:,线性表L已存在。,若cur_e是L的元素,但不是第一个,则用pre_e 返回它的前驱,否则操作失败,pre_e无定义。,(求数据元素的前驱),12,NextElem( L, cur_e, &next_e ),初始条件:操作结果:,线性表L已存在。,若cur_e是L的元素,但不是最后一个,则用next_e返回它的后继,否则操作失败,next_e无定义。,(求数据元素的后继),13,GetElem( L, i, &e ),初始条件: 操作结果:,线性表L已存在,且 1iLengthList(L)。,用 e 返回L中第 i 个元素的值。,(求线性表中某个数据元素),14,LocateElem( L, e, compare( ) ),初始条件:操作结果:,线性表L已存在,e为给定值, compare( )是元素判定函数。,返回L中第1个与e满足关系compare( )的元素的位序。若这样的元素不存在,则返回值为0。,(定位函数),15,ListTraverse(L, visit( ),初始条件:操作结果:,线性表L已存在,Visit() 为某个访问函数。,依次对L的每个元素调用函数visit( )。一旦visit( )失败,则操作失败。,(遍历线性表),16,加工型操作:,ClearList( &L ),PutElem( &L, i, e ),ListInsert( &L, i, e ),ListDelete(&L, i, &e),17,ClearList( &L ),初始条件:操作结果:,线性表L已存在。,将L重置为空表。,(线性表置空),PutElem( &L, i, e ),初始条件:操作结果:,线性表L已存在,且 1iLengthList(L) 。,L中第i个元素赋值同e的值。,(改变数据元素的值),18,ListInsert( &L, i, e ),初始条件:操作结果:,线性表L已存在, 且1iLengthList(L)+1 。,在L的第i个元素之前插入新的元素e,L的长度增1。,(插入数据元素),19,ListDelete(&L, i, &e),初始条件:操作结果:,线性表L已存在且非空, 1iLengthList(L) 。,删除L的第i个元素,并用e返回其值,L的长度减1。,(删除数据元素),20,假设:有两个集合A 和 B 分别用两个线性表 LA 和 LB 表示,即:线性表中的数据元素即为集合中的成员。现要求一个新的集合AAB。,利用上述定义的线性表可以实现其它更复杂的操作。,例2-1,21,要求对线性表作如下操作:扩大线性表 LA,将存在于线性表LB 中而不存在于线性表 LA 中的数据元素插入到线性表 LA 中去。,算法思想:,22,1. 从线性表LB中依次察看每个数据元素;,2. 依值在线性表LA中进行查访;,3. 若不存在,则插入之。,GetElem(LB, i,&e),LocateElem(LA, e, equal( ),ListInsert(LA, n+1, e),操作步骤:,23,GetElem(Lb, i, e); / 取Lb中第i个数据元素赋给e if ( ! LocateElem(La, e, equal( ) ) ListInsert(La, +La_len, e); / La中不存在和 e 相同的数据元素,则插入之,void union(List ,for (i = 1; i = Lb_len; + i) , / union,O(ListLength(LA)ListLength(LB);,24,例2-2,已知线性表LA和LB是非递减的,将两表合并成新的线性表LC,且LC也是非递减的。,25,算法思想:,将LA、LB两表中的元素逐一按序加入到一个新表LC中。 设 La = (a1, , ai, , an), Lb = (b1, , bj, , bm) , Lc = (c1, , ck, , cm+n),1. 分别从La和Lb中取得当前元素ai和bj; 2. 若aibj,则将ai插入到Lc中,否则将bj插入到Lc中。,操作步骤:,26,void MergeList(List La, List Lb, List &Lc) / 本算法将非递减的有序表 La 和 Lb 归并为 Lc / merge_list,while (i = La_len) & (j = Lb_len) / La 和 Lb 均不空 while (i=La_len) / 若 La 不空 while (j=Lb_len) / 若 Lb 不空,InitList(Lc); / 构造空的线性表 Lc i = j = 1; k = 0; La_len = ListLength(La); Lb_len = ListLength(Lb);,O(ListLength(LA)ListLength(LB),27,while (i=La_len) ,28,while (i = La_len) / 当La不空时 GetElem(La, i+, ai); ListInsert(Lc, +k, ai); / 插入 La 表中剩余元素,while (j = Lb_len) / 当Lb不空时 GetElem(Lb, j+, bj); ListInsert(Lc, +k, bj); / 插入 Lb 表中剩余元素,29,线性表的顺序表示: 用一组地址连续的储存单元依次存放线性表的数据元素。,2.2 线性表的顺序表示和实现,30,以“存储位置相邻”表示有序对 即:LOC(ai) = LOC(ai-1) + L 一个数据元素所占存储量,所有数据元素的存储位置均取决于第一个数据元素的存储位置,即 LOC(ai) = LOC(a1) + (i-1)L 基地址,31,32,顺序映像的 C 语言描述:,typedef struct SqList; / 俗称 顺序表,#define LIST_INIT_SIZE 80 / 线性表存储空间的初始分配量#define LISTINCREMENT 10 / 线性表存储空间的分配增量,ElemType *elem; / 存储空间基址,int length; / 当前长度,int listsize; / 当前分配的存储容量 / (以sizeof(ElemType)为单位),33,线性表的基本操作在顺序表中的实现:,InitList(&L) / 结构初始化,LocateElem(L, e, compare() / 查找,ListInsert(&L, i, e) / 插入元素,ListDelete(&L, i,&e) / 删除元素,34,Status InitList_Sq( SqList& L ) / 构造一个空的线性表 / InitList_Sq,算法时间复杂度:,O(1),L.elem = (ElemType*) malloc (LIST_ INIT_SIZEsizeof (ElemType);if (!L.elem) exit (OVERFLOW);,L.length = 0;L.listsize = LIST_INIT_SIZEreturn OK;,结构初始化InitList(&L),35,e =,38,i,1,2,3,4,1,8,50,基本操作是:将顺序表中的元素逐个和给定值 e 相比较。,查找操作LocateElem(L, e, compare(),36,int LocateElem_Sq(SqList L, ElemType e, Status (*compare)(ElemType, ElemType) / 在顺序表中查询第一个满足判定条件的数据元素, / 若存在,则返回它的位序,否则返回 0 / LocateElem_Sq,O( ListLength(L) ),算法的时间复杂度为:,i = 1; / i 的初值为第 1 元素的位序 p = L.elem; / p 的初值为第 1 元素的存储位置,while (i = L.length ,if (i =i-1; -j) L.elemj+1= L.elemj;L.elemj+1=e;,39,Status ListInsert_Sq(SqList &L, int i, ElemType e) / 在顺序表L的第 i 个元素之前插入新的元素e, / i 的合法范围为 1iL.length+1 / ListInsert_Sq,q = ,算法时间复杂度为:,O( ListLength(L) ),40,if (L.length = L.listsize) / 当前存储空间已满,增加分配 newbase = (ElemType *) realloc (L.elem, (L.listsize+LISTINCREMENT)*sizeof (ElemType); if (!newbase) exit(OVERFLOW); / 存储分配失败 L.elem = newbase; / 新基址 L.listsize += LISTINCREMENT; / 增加存储容量,if (i L.length+1) return ERROR; / 插入位置不合法,41,考虑移动元素的平均情况:,假设在第 i 个元素之前插入的概率为 , 则在长度为n 的线性表中插入一个元素所需移动元素次数的期望值为:,若假定在线性表中任何一个位置上进行插入的概率都是相等的,则移动元素的期望值为:,42,(a1, , ai-1, ai, ai+1, , an) 改变为 (a1, , ai-1, ai+1, , an),ai+1,an, ,表的长度减少,删除操作ListDelete(&L, i, &e),43,L.length-1,0,87,56,例如:ListDelete_Sq(L, 5, e),p = ,44,Status ListDelete_Sq (SqList &L, int i, ElemType &e) / ListDelete_Sq,for (+p; p data表示p指向结点的数据域(*p).nextp-next表示p指向结点的指针域,二、结点和单链表的 C 语言描述,LinkList L; / L 为单链表的头指针,52,三、单链表操作的实现,GetElem(L, i, e) / 取第i个数据元素,ListInsert(&L, i, e) / 插入数据元素,ListDelete(&L, i, e) / 删除数据元素,ClearList(&L) / 重置线性表为空表,CreateList(&L, n) / 生成含 n 个数据元素的链表,53,GetElem(L, i, &e),因此,查找第 i 个数据元素的基本操作为:移动指针,比较 j 和 i 。,单链表是一种顺序存取的结构,为找第 i 个数据元素,必须先找到第 i-1 个数据元素。,令指针 p 始终指向线性表中第 j 个数据元素。,54,While (p,55,Status GetElem_L(LinkList L, int i, ElemType &e) / L是带头结点的链表的头指针,以 e 返回第 i 个元素 / GetElem_L,算法时间复杂度为:,O(ListLength(L),p = L-next; j = 1; / p指向第一个结点,j为计数器,while (p / 顺指针向后查找,直到 p 指向第 i 个元素 / 或 p 为空,if ( !p | ji ) return ERROR; / 第 i 个元素不存在e = p-data; / 取得第 i 个元素return OK;,56,线性表的操作ListInsert(&L, i, e) 在单链表中的实现:,有序对 改变为 和,57,因此,在单链表中第 i 个结点之前进行插入的基本操作为: 找到线性表中第i-1个结点,然后修改其指向后继的指针。,可见,在链表中插入结点只需要修改指针。但同时,若要在第 i 个结点之前插入元素,修改的是第 i-1 个结点的指针。,58,Status ListInsert_L(LinkList L, int i, ElemType e) / L 为带头结点的单链表的头指针,本算法 / 在链表中第i 个结点之前插入新的元素 e / LinstInsert_L,算法的时间复杂度为:,O(ListLength(L),p = L; j = 0;while (p / i 大于表长或者小于1,59,s = (LinkList) malloc ( sizeof (LNode); / 生成新结点s-data = e; s-next = p-next; p-next = s; / 插入return OK;,s,p,60,线性表的操作ListDelete (&L, i, &e) 在链表中的实现:,有序对 和 改变为 ,61,在单链表中删除第 i 个结点的基本操作为:找到线性表中第i-1个结点,修改其指向后继的指针。,q = p-next; p-next = q-next; e = q-data; free(q);,p,q,62,Status ListDelete_L(LinkList L, int i, ElemType &e) / 删除以 L 为头指针(带头结点)的单链表中第 i 个结点 / ListDelete_L,算法的时间复杂度为:,O(ListLength(L),p = L; j = 0;while (p-next / 删除位置不合理,q = p-next; p-next = q-next; / 删除并释放结点e = q-data; free(q);return OK;,63,操作 ClearList(&L) 在链表中的实现:,void ClearList( / ClearList,free(p);,算法时间复杂度:,O(ListLength(L),64,如何从线性表得到单链表?,链表是一个动态的结构,它不需要予分配空间,因此生成链表的过程是一个结点“逐个插入” 的过程。,65,例如:逆位序输入 n 个数据元素的值, 建立带头结点的单链表。,操作步骤:,一、建立一个“空表”;,二、输入数据元素an, 建立结点并插入;,三、输入数据元素an-1, 建立结点并插入;,an,an,an-1,四、依次类推,直至输入a1为止。,66,void CreateList_L(LinkList &L, int n) / 逆序输入 n 个数据元素,建立带头结点的单链表 / CreateList_L,算法的时间复杂度为:,O(Listlength(L),L = (LinkList) malloc (sizeof (LNode);L-next = NULL; / 先建立一个带头结点的单链表,for (i = n; i 0; -i) p = (LinkList) malloc (sizeof (LNode); scanf( / 插入,67,补充作业:写出按正位序建立一个单链表的算法。,68,回顾 2.1 节中两个例子的算法,看一下当线性表分别以顺序存储结构和链表存储结构实现时,它们的时间复杂度为多少?,69,void union(List /for / union,控制结构:基本操作:,for 循环GetElem, LocateElem 和 ListInsert,当以顺序映像实现抽象数据类型线性表时为: O( ListLength(La)ListLength(Lb) ),当以链式映像实现抽象数据类型线性表时为: O( ListLength(La)ListLength(Lb) ),例2-1,70,void MergeList(List La, List Lb, List ,控制结构:基本操作:,三个并列的while循环GetElem, ListInsert,当以顺序映像实现抽象数据类型线性表时为: O( ListLength(La)+ListLength(Lb) ),当以链式映像实现抽象数据类型线性表时为: O( (ListLength (La)+ListLength (Lb)2 ),例2-2,71,Pa=null,while ( pa ,pc next = pa? pa : pb ; free(Lb);,O( listlength(La)+listlength(Lb) ),72,优点它是一种动态结构,整个存储空间为多个链表共用不需预先分配空间插入、删除操作方便缺点指针占用额外存储空间不能随机存取,查找速度慢,链式存储线性表的优缺点:,73,最后一个结点的指针域的指针又指回第一个结点的链表。,a1 a2 . an,循环链表,和单链表的差别仅在于,判别链表中最后一个结点的条件不再是“后继是否为空”,而是“后继是否为头结点”。,四、其他形式的链表,74,双向链表,typedef struct DuLNode ElemType data; / 数据域 struct DuLNode *prior; / 指向前驱的指针域 struct DuLNode *next; / 指向后继的指针域 DuLNode, *DuLinklist;,p-prior-next= p= p-next-proir;,75,a1 a2 . an,双向循环链表,空表,非空表,76,双向链表的操作特点:,“查询” 和单链表相同。,“插入” 和“删除”时需要同时修改两个方向上的指针。,77,s-prior= p-prior; p-prior -next=s;s-next = p; p-prior = s ;,p,s,插入操作,78,删除操作,p-prior-next = p-next;p-next-prior = p-prior;,p,79,在计算机中,可以用一个线性表来表示: P = (p0, p1, ,pn),一元多项式,2.4 一元多项式的表示及相加,80,但是对于形如 S(x) = 1 + 3x10000 2x20000的多项式,上述表示方法是否合适?,81,一般情况下的一元稀疏多项式可写成 Pn(x) = p1xe1 + p2xe2 + + pmxem其中:pi 是指数为ei 的项的非零系数, 0 e1 e2 em = n,可以下列线性表表示:(p1, e1), (p2, e2), , (pm,em) ),82,P999(x) = 7x3 - 2x12 - 8x999,例如:,可用线性表 ( (7, 3), (-2, 12), (-8, 999
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 建立健全特种设备安全培训与认证体系
- 终身教育视角下老年人健康教育系统设计
- 一年级珠心算教学中的练评一体化探索
- 校园欺凌的治理逻辑与进路选择
- 护理搬运法课件
- 中药药理学:化痰止咳平喘药讲课件
- 公司各类软件管理制度
- 公司员工体验式管理制度
- 公司多元化目标管理制度
- 公司对外借款担保管理制度
- 2025年上半年山东济宁市任城区事业单位招聘工作人员(卫生类)161人易考易错模拟试题(共500题)试卷后附参考答案
- 股骨头坏死中医护理常规
- 水稳施工技术课件
- 父母育儿压力量表(PSI)
- 河北省部分校2024-2025学年九年级下学期开学测试历史试题(含答案)
- 智能机器人技术研发战略合作协议
- 233KWh 定制户外一体柜储能系统项目技术方案
- 2024-2030年中国电船行业前景展望及投资战略分析报告
- 2025版国家开放大学法学本科《知识产权法》期末纸质考试第三大题名词解释题库
- 保安反恐防暴培训
- 《无人机测绘技术》项目2任务1无人机航测任务规划
评论
0/150
提交评论