数据结构第二章性表--高职高专(第四版).pptVIP

数据结构第二章性表--高职高专(第四版).ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
2.4 线性表应用举例 多项式中每个非零项的系数用一个结点来表示,结点中含有两个数据域和一个 指针域,两个数据域分别存放非零项的系数和指数。结点示意图和结点的结构 类型定义如下: 2.4 线性表应用举例 2.3 线性表的链式存储结构及其运算 void insert(DUPNODE *p,DUPNODE *q) { /*把q结点插在双向链表的p结点之后*/ q-prior=p; q-next=p-next; (p-next)-prior=q; p-next=q; } 2.3 线性表的链式存储结构及其运算 3. 删除运算 将双向链表中的 p 结点删除。 2.3 线性表的链式存储结构及其运算 void delete (DUPNODE *p) /*在双向链表中删除结点p*/ { (p-prior)-next=p-next; (p-next)-prior=p-prior; free (p); } 2.4 线性表应用举例 例2.1 有两个线性表A和B,都是循环链表存储结构,两个链表头指针分别为 head1和head2 ,将B链表链接到A链表的后面, 合并成一个链表。 2.4 线性表应用举例 NODE *connect(NODE *head1,NODE *head2) { /*把循环链表A和B合并成一个循环链表。head1和head2分别为两个循环链表的头指针*/ NODE *p,*q; p=head1-next; while(p-next!=head1) /*找head1的最后一个结点*/ p=p-next; q=head2-next; while(q-next!=head2) /*找head2的最后一个结点*/ q=q-next; p-next=head2-next; /*A,B两表链接*/ q-next=head1; free(head2); /*释放B表表头结点*/ return(head1); } 2.4 线性表应用举例 例2.2 一元多项式的加法运算。设有两个一元多项式分别为: An(x)=a0+a1x+a2x2+…+anxn Bm(x)=b0+b1x+b2x2 +…+bm x m 多项式An中n+1个系数,系数可用线性表表示为: A=(a0,a1,a2,…an) 多项式Bm中m+1个系数,系数可用线性表表示为: B=(b0,b1,b2,…bm) 设m≤n,两个多项式的和Rn(x)=An(x)+bm(x)的系数可用线性表表示为: R=(a0+b0,a1+b1,…am+bm,am+1,…,an) 由上面3个多项式系数组成的线性表A,B,R可采用顺序存储结构存储在计算机中。用这种顺序存储方式,很容易实现加法运算。但是当多项式中的零系数很多时,用顺序存储方式就不合适了,会浪费大量存储空间。如有一多项式A(x)=1+2x200+3x300。它仅有3个非零元素,实际上只需要3个存储单元。而用顺序表表示时,它却需要301个存储单元。为避免存储空间的浪费,对一元多项式我们采用链式存储方式。 typedef struct pnode { int coef; /*系数以整型为例*/ int exp; /*指数*/ struct pnode *next; }PNODE; 设有多项式 A(x)=1+2x+4x3 (1) B(x)=2-2x+3x2 (2) 多项式(1)加多项式(2)的和为多项式(3): R(x)=3+3x2 +4x3 (3) 多项式(1),(2),(3)可用链表表示如下: 链式存储的一元多项式加法运算的C++算法(ex2_11.cpp)如下: 下一张幻灯片 上一张幻灯片 第 2 章 线性表 本章的主要内容 线性表的定义及其特征。 线性表的顺序存储和实现。 线性表的链式存储和实现。 循环链表和双向循环链表的存储和实现。 线性表的应用举例。 数组与矩阵的压缩存储。 2.1 线性表的基本概念 2.1.1 线性表的定义 本节主要讨论线性表的定义以及线性表的基本操作。 线性表(linear list)是由 n(n=0)个数据元素组成的有限序列。 线性表可以用一个标识符来命名,如果用A来表示线性表,则: A=(a1 ,a2

文档评论(0)

wyw118 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档