- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构c语l言描述第2章
多项式相加的运算规则是:两个多项式中所有指数相同的项的对应系数相加, 若和不为零,则构成“和多项式”中的一项;所有指数不相同的项均复抄到“和多项式”中。 以单链表作为存储结构,并且 “和多项式“中的结点无需另外生成, 则可看成是将多项式B加到多项式A中,由此得到下列运算规则(设p、q分别指向多项式A、 B的一项,比较结点的指数项): 若p-expq-exp, 则结点p所指的结点应是“和多项式”中的一项, 令指针p后移; 若p-expq-exp,则结点q所指的结点应是“和多项式”中的一项, 将结点q插入在结点p之前,且令指针q在原来的链表上后移; 若p-exp=q-exp, 则将两个结点中的系数相加, 当和不为零时修改结点p的系数域, 释放q结点;若和为零,则和多项式中无此项, 从A中删去p结点, 同时释放p和q结点。 void polyadd(Polylist polya; Polylist polyb) /*此函数用于将两个多项式相加,然后将和多项式存放在多项式polya中,并将多项式ployb删除*/ { Polynode *p, *q, *pre; *temp; int sum; p=polya-next ; /* 令p和q分别指向polya和polyb多项式链表中的第一个结点 */ q=polyb-next ; pre=polya; /* pre指向和多项式的尾结点 */ while (p! =NULL q! =NULL) /* 当两个多项式均未扫描结束时 */ { if (p-exp q-exp) /* 如果p指向的多项式项的指数小于q的指数, 将p结点加入到和多项式中 */ { pre-next=p; pre=pre-next; p=p-next; } else if ( p-exp==q-exp)/* 若指数相等, 则相应的系数相加 */ {sum=p-coef + q-coef ; if (sum![KG-*2]=0) {p-coef=sum; pre-next=p; pre=pre-next; p=p-next; } else { temp=p-next ; free(p); p=temp ; /* 若系数和为零, 则删除结点p与q, 并将指针指向下一个结点 */ temp=q-next; free(q); q=temp ; } } else {pre-next=q; pre=pre-next; /* 将q结点加入到和多项式中 */ q =q-next; } } } if(p! =NULL) /* 多项式A中还有剩余, 则将剩余的结点加入到和多 项式中 */ pre-next=p; else /* 否则, 将B中的结点加入到和多项式中 */ pre-next=q; } 【算法2.24 多项式相加】 图2.20 多项式相加得到的多项式和 【算法2.13 循环单链表的合并算法(1)】 采用上面的方法,需要遍历链表,找到表尾,其执行时间是O(n)。 若在尾指针表示的单循环链表上实现,则只需要修改指针,无需遍历,其执行时间是 O(1)。 LinkList merge --2(LinkList RA, LinkList RB) { /* 此算法将两个链表首尾连接起来 */ Node *p; p=RA-next; /* 保存链表RA的头结点地址 */ RA-next=RB-next-next; /*链表RB的开始结点链到链表RA的终端结点之后 */ free(RB-next); /* 释放链表RB的头结点 */ RB-next=p; /* 链表RA的头结点链到链表RB的终端结点之后 */ return RB; /* 返回新循环链表的尾指针 */ } 【算法2.14 循环单链表的合并算法(2)】 2.3.4 双向链表 循环单链表的出现,虽然能够实现从任一结点出发沿着链能找到其
文档评论(0)