网站大量收购独家精品文档,联系QQ:2885784924

数据结-第4次课第二章线性表(双向链表多项式).ppt

数据结-第4次课第二章线性表(双向链表多项式).ppt

  1. 1、本文档共20页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结-第4次课第二章线性表(双向链表多项式)

2.3.3 双向链表 双向链表(Double linked list):在单链表的每个结点里再增加一个指向其直接前趋的指针域prior。这样就形成的链表中有两个方向不同的链,故称为双向链表。形式描述为: struct DuLNode{ datatype data; DuLNode *prior,*next; };; 双链表一般由头指针唯一确定的,将头结点和尾结点链接起来构成循环链表,并称之为双向链表。 设指针p指向某一结点,则双向链表结构的对称性可用下式描述: p—prior—next=p=p—next—prior ;双向链表结点p前的插入数据x的操作:;双向链表结点p前的插如数据x的操作:;双向链表结点p前的插如数据x的操作:;ai+1;ai+1;ai+1;2.4 一元多项式的表示及相加; 一般情况下的一元稀疏多项式可写成 Pn(x) = p1xe1 + p2xe2 + ┄ + pmxem 其中:pi 是指数为ei 的项的非零系数, 0≤ e1 e2 ┄ em = n; P999(x) = 7x3 - 2x12 - 8x999;ADT Polynomial { 数据对象: 数据关系:; CreatPolyn ( P, m ) DestroyPolyn ( P ) PrintPolyn ( P ); PolynLength( P ) AddPolyn ( Pa, Pb ) SubtractPolyn ( Pa, Pb ) 相减操作… … } ADT Polynomial;二、一元多项式的实现:; 存储结构:用线性链表表示。有头结点,每个结点有 coef:系数 exp指数 next:指针。其中,头结点的exp为-1。;例:求两多项式的和多项式 A (x) = 7 +3x + 9 x 8 + 5 x 17 B (x) = 8 x +22 x 7 – 9 x 8 ;一元多项式加法算法主要步骤: 分别对两个链表ha 、hb进行扫描,ha和hb分别指向两个表的头结点,设 工作指针pa 、 pb分别指向两个多项式当前进行比较的结点,qa指针指向pa的前驱, qb指针指向pb的前驱,初始: qa=ha; pa=ha-next; pb=hb-next; 若pa,pb都不为空:则比较两者指数: pa-exp pb-exp: qa,pa后移; pa-exp == pb-exp:将pb所指结点的系数“加”到pa所指结点 的系数上;若和为0,则pa所指结点删除。pb所指结 点删除,qa, pa, qb, pb调整;否则pb所指结点删除, qa, pa, qb, pb调整。 pa-exp pb-exp : ???表hb中pb所指结点插入到ha表pa所指结点之前; qb, pb后移。;int comp(int a,int b) { if(ab) return -1; if(a==b) return 0; else return 1; } PloyAdd(ha,hb) { qa=ha;pa=ha-next; pb=hb-next; while(pa!=NULL pb!=NULL) switch(comp(pa-exp,pb-exp)){ -1: qa=pa; pa=pa-next; break; 0: pa-coef+=pb-coef; if(pa-coef==0) { qa-next=pa-next; delete pa; pa=qa; } else qa=pa; pa=pa-next; qb-next = pb-next; delete pb; ;1、线性表v的数据递增有序,试将x插入表中并保持有序性 (1)表顺序表示 (2)链表表示 (3)带有头结点的链表 2、写一个线性表的转置算法(顺序和链表表示两种情况) (a1,a2,….,an)变为(an,an-1,….,a1)

文档评论(0)

cgsx259 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档