LeetCode热题Hot100 - 合并K个升序链表

一刷~

给你一个链表数组,每个链表都已经按升序排列。

请你将所有链表合并到一个升序链表中,返回合并后的链表。

思路:

逆天了- -困难模式一次过- -

第一反应,n个列表,两两合并,n-1次遍历即可,但是这样n-1次排序会浪费很多时间。

第二反应,n个列表取头部node,n个node排序,取最小的,然后用同链表中次小的代替它。这样一来,需要对n个值不停排序。有没有不用一直排序,每次都取最小值的方法呢?

最小堆呀- -

用最小堆每次弹出n个node中最小的。那么最后一个问题,怎么确定最小的node属于哪个链表(因为要用同链表次小值代替它)?---索引堆。 Over- -

python 复制代码
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
import heapq

class Solution:
    def mergeKLists(self, lists: List[Optional[ListNode]]) -> Optional[ListNode]:
        nodes = []
        for i in range(len(lists)):
            if lists[i]:
                nodes.append([lists[i].val, i])
        
        heapq.heapify(nodes)

        head = ListNode(0)
        p1 = head

        while len(nodes):
            _, idx = heapq.heappop(nodes)
            p1.next = lists[idx]
            lists[idx] = lists[idx].next
            p1 = p1.next

            if lists[idx]:
                heapq.heappush(nodes, [lists[idx].val, idx])
        
        return head.next
相关推荐
xiaoye-duck15 分钟前
《算法题讲解指南:递归,搜索与回溯算法--综合练习》--14.找出所有子集的异或总和再求和,15.全排列Ⅱ,16.电话号码的字母组合,17.括号生成
c++·算法·深度优先·回溯
OOJO15 分钟前
c++---vector介绍
c语言·开发语言·数据结构·c++·算法·vim·visual studio
汀、人工智能17 分钟前
05 - 函数基础
数据结构·算法·数据库架构·05 - 函数基础
HAPPY酷34 分钟前
Python高级架构师之路——从原理到实战
java·python·算法
枫叶林FYL1 小时前
第9章 因果推理与物理理解
人工智能·算法·机器学习
小白zlm1 小时前
预畸变双线性变换
单片机·嵌入式硬件·算法·电机控制
wuweijianlove2 小时前
算法复杂度估算的实验建模与可视化表达的技术6
算法
执笔画流年呀2 小时前
7大排序算法
java·算法·排序算法
AI成长日志2 小时前
【算法学习专栏】动态规划基础·中等两题精讲(198.打家劫舍、322.零钱兑换)
学习·算法·动态规划
计算机安禾2 小时前
【数据结构与算法】第28篇:平衡二叉树(AVL树)
开发语言·数据结构·数据库·线性代数·算法·矩阵·visual studio