如何合并多个升序链表?

前言

本文主要介绍如何将多个小的升序链表合并一个大的升序链表。

需求描述

给出K个升序链接,要求把这K个升序链表合并成一个,并且这个链表也是升序的。

例如:A = [1,5,6]B = [2,3,8], C = [4,4,9] 将这3个链表合并成一个链表D,合并后D = [1,2,3,4,4,5,6,8,9],并且将D的第一个节点返回。

思路解析

我们可以采用优先级队列来实现,先把每个链表的头结点放到一个优先级队列里,优先级队列也叫小根堆。

在放小根堆的时候,谁小就把谁放在最上面。需要注意的是,我们放入的时候,放入的是节点,所以通过这个节点是可以访问整个链表的。

我们看下处理过程:

  1. 首先把每个链接的头结点放入小根堆中:1,2,4
  2. 首先弹出最小的值:1
  3. 1节点的下一个节点5放入小根堆中,此时小根堆会自动调整顺序,此时为:2, 4, 5
  4. 2节点弹出,让1节点的next指针指向2节点,并且将2节点的下一个节点6放入小根堆,此时已弹出的节点为 1,2,而小根堆为4, 5, 6
  5. 将<
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值