找回密码
 注册
关于网站域名变更的通知
查看: 394|回复: 3
打印 上一主题 下一主题

如何将两个有序链表并为一个有序链表

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2016-7-13 15:14 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
假设头指针为La和Lb的单链表分别为线性表LA和LB的存储结构,现要归并La和Lb得到单链表Lc,按照算法MergeList的思想,需设立3个指针pa、pb和pc,其中pa和pb分别指向La表和Lb表中当前待比较插入的结点,而pc指向Lc表中当前最后一个结点,若pa->data≤pb->data,则将pa所指向结点之后,否则将pb所指向结点链接到pc所指结点之后。显然,指针的初始状态为:当LA和LB为非空表时,pa和pb分别指向La和Lb表中第一个结点,否则为空;pc指向空表Lc中的头结点。由于链表的长度为隐含的,则第一个循环执行的条件时pa和pb皆非空,当其中一个为空时,说明有一个表的元素已归并完,则只要将另一个表的剩余段链接在pc所指结点之后即可。由此得到归并两个单链表的算法。& y$ S, O+ J! E; a/ [$ u2 _
voidMergeList_L(LinkList &La,LinkList &Lb,LinkList &Lc,){  T6 c3 p! G$ E$ x# W) e+ J1 s0 o0 u
//已知单链线性表La和Lb的元素按值非递减排列。' g- e# a* x" K* K. f
//归并La和Lb得到新的单链线性表Lc,Lc的元素也按非递减排列。/ o, |6 e4 Q8 }' a
pa=La->next;pb=Lb->next;
; w9 \7 k% ]  K2 }) S+ D  |" N7 ?Lc=pc=La;           //用La的头结点作为Lc的头结点
  i' j7 \* n8 ywhile(pa&&pb){$ p8 H) M; m: y$ A
if(pa->data<=pb->data){. u2 n9 Y  b( k1 M3 b
pc->next=pa;pc=pa;pa=pa->next;. V& z+ f. b! t; @4 q) Y" ]% o( e5 r
}/ W- e2 m- k$ c4 [7 x
else{pc->next=pb;pc=pb;pb=pb->next;}. Q) V- q) r! R
}- s8 @* n7 v; N- x5 U3 Q$ V
pc->next=pa?=pa:pb;//插入剩余段
7 w/ R) q3 D1 w1 e3 i: gfree(Lb);       //释放Lb的头结点
+ G  S8 Y! W5 g}//MergeList_L

该用户从未签到

4#
发表于 2016-7-14 16:19 | 只看该作者
谢谢楼主,一步步来,学习中……7 q6 L& ^/ k6 M8 Z4 C! `

该用户从未签到

3#
发表于 2016-7-14 14:31 | 只看该作者
谢谢O(∩_∩)O哈哈~谢谢O(∩_∩)O哈哈, p9 i; w; D- N# O! r( L

该用户从未签到

2#
发表于 2016-7-13 17:55 | 只看该作者
学习中,谢谢分享8 Q$ P( `& y7 w  l. W& L# F/ x
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-11-23 22:58 , Processed in 0.156250 second(s), 24 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表