当前位置:网站首页>Leetcode 23. 合并K个升序链表
Leetcode 23. 合并K个升序链表
2022-07-04 07:41:00 【von Libniz】
题目链接:https://leetcode.cn/problems/merge-k-sorted-lists/
题目描述
给你一个链表数组,每个链表都已经按升序排列。请你将所有链表合并到一个升序链表中,返回合并后的链表。
示例 1:
输入:lists = [[1,4,5],[1,3,4],[2,6]]
输出:[1,1,2,3,4,4,5,6]
解释:链表数组如下:
[
1->4->5,
1->3->4,
2->6
]
将它们合并到一个有序链表中得到。
1->1->2->3->4->4->5->6
示例 2:
输入:lists = []
输出:[]
示例 3:
输入:lists = [[]]
输出:[]
这题显然是数组k路归并的扩展,而数组k路归并存在三种解法(假设k路数组的所有元素数为n):
(1)k路数组拷贝至同一数组,再统一排序
(2)k路数组进行k次归并
(3)使用最小堆,依次从k个数组中找到最小值,重复n次
而这题把数组换成了链表,那使用第三种方法是比较合适的。
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, val=0, next=None):
# self.val = val
# self.next = next
class Solution:
def mergeKLists(self, lists: List[Optional[ListNode]]) -> Optional[ListNode]:
if not lists:
return None
k = len(lists)
dummy = ListNode(val=-1)
tail = dummy
heap = []
# put each list head to min heap
for i, node in enumerate(lists):
if node is not None:
heap.append((node.val, i, node)) # 当val相同通过link_index:i比较
heapq.heapify(heap)
# find min node n times
while len(heap) > 0:
_, idx, cur_node = heapq.heappop(heap)
tail.next = cur_node
tail = cur_node
if cur_node.next is not None:
heapq.heappush(heap, (cur_node.next.val, idx, cur_node.next))
return dummy.next
边栏推荐
- Google's official response: we have not given up tensorflow and will develop side by side with Jax in the future
- Activiti常见操作数据表关系
- L1-028 judging prime number (10 points)
- How to buy financial products in 2022?
- MySQL中的文本處理函數整理,收藏速查
- 真空介电常数和真空磁导率究竟是由什么决定的?为何会存在这两个物理量?
- Routing decorator of tornado project
- JVM中堆概念
- 2022-021rts: from the second half of the year
- Two years ago, the United States was reluctant to sell chips, but now there are mountains of chips begging China for help
猜你喜欢

L2-013 red alarm (C language) and relevant knowledge of parallel search

What are the work contents of operation and maintenance engineers? Can you list it in detail?

Node foundation ~ node operation

The frost peel off the purple dragon scale, and the xiariba people will talk about database SQL optimization and the principle of indexing (primary / secondary / clustered / non clustered)

大厂技术专家:架构设计中常用的思维模型

Easy to understand: understand the time series database incluxdb

Technical experts from large factories: common thinking models in architecture design

Zephyr Learning note 2, Scheduling

L1-027 rental (20 points)

深入浅出:了解时序数据库 InfluxDB
随机推荐
Directory of tornado
Mysql database - function constraint multi table query transaction
Relations courantes de la fiche de données d'exploitation pour les activités
L2-013 red alarm (C language) and relevant knowledge of parallel search
[kubernetes series] kubesphere is installed on kubernetes
【FreeRTOS】FreeRTOS學習筆記(7)— 手寫FreeRTOS雙向鏈錶/源碼分析
谷歌官方回应:我们没有放弃TensorFlow,未来与JAX并肩发展
[web security] nodejs prototype chain pollution analysis
L1-023 output gplt (20 points)
How to buy financial products in 2022?
真空介电常数和真空磁导率究竟是由什么决定的?为何会存在这两个物理量?
When JDBC connects to es query, is there a God who meets the following situation?
BUUCTF(4)
2022-021ARTS:下半年開始
Rapidjson reading and writing JSON files
Introduction to sap commerce cloud B2B organization function
[Chongqing Guangdong education] National Open University spring 2019 770 real estate appraisal reference questions
[network security] what is emergency response? What indicators should you pay attention to in emergency response?
[untitled] notice on holding "2022 traditional fermented food and modern brewing technology"
Easy to understand: understand the time series database incluxdb