LeetCode 合并K个升序链表

题目地址:https://leetcode.cn/problems/merge-k-sorted-lists/description/

算法思路:

先把每个链表的头加入小顶堆 ,把堆顶节点加入head并出堆,

如果这个节点的下一个元素不为空则加入堆并调整

直到所有元素全部出堆

具体实现如下

go 复制代码
func mergeKLists(lists []*ListNode) *ListNode {
	size := 0
	heap := []*ListNode{}

	for i := 0; i < len(lists); i++ {
		if lists[i] != nil {
			size++
			heap = append(heap, lists[i])
		}
	}
	if size == 0 {
		return nil
	}
	for i := size/2 - 1; i >= 0; i-- {
		heapify(heap, i, size)
	}

	head := &ListNode{}
	tail := head
	for size > 0 {
		minNode := heap[0]
		tail.Next = minNode
		tail = tail.Next
		if minNode.Next != nil {
			heap[0] = minNode.Next
			heapify(heap, 0, size)
		} else {
			size--
			swap(heap, 0, size)
			heapify(heap, 0, size)
		}

	}
	return head.Next
}

// 调整小顶堆
func heapify(heap []*ListNode, i, size int) {
	left := i*2 + 1
	small := left
	for left < size {
		small = left
		if small+1 < size && heap[small].Val > heap[small+1].Val {
			small = left + 1
		}
		if heap[small].Val < heap[i].Val {
			swap(heap, small, i)
			i = small
			left = i*2 + 1
		} else {
			break
		}
	}
}

func swap(heap []*ListNode, i, j int) {
	heap[i], heap[j] = heap[j], heap[i]
}
相关推荐
Tony Bai41 分钟前
再见,丑陋的 container/heap!Go 泛型堆 heap/v2 提案解析
开发语言·后端·golang
We་ct1 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
念何架构之路3 小时前
Go进阶之panic
开发语言·后端·golang
先跑起来再说3 小时前
Git 入门到实战:一篇搞懂安装、命令、远程仓库与 IDEA 集成
ide·git·后端·elasticsearch·golang·intellij-idea
努力学算法的蒟蒻4 小时前
day79(2.7)——leetcode面试经典150
算法·leetcode·职场和发展
2401_841495644 小时前
【LeetCode刷题】二叉树的层序遍历
数据结构·python·算法·leetcode·二叉树··队列
2401_841495645 小时前
【LeetCode刷题】二叉树的直径
数据结构·python·算法·leetcode·二叉树··递归
我是咸鱼不闲呀5 小时前
力扣Hot100系列19(Java)——[动态规划]总结(上)(爬楼梯,杨辉三角,打家劫舍,完全平方数,零钱兑换)
java·leetcode·动态规划
铉铉这波能秀6 小时前
LeetCode Hot100数据结构背景知识之列表(List)Python2026新版
数据结构·leetcode·list
仟濹6 小时前
算法打卡 day1 (2026-02-06 周四) | 算法: DFS | 1_卡码网98 可达路径 | 2_力扣797_所有可能的路径
算法·leetcode·深度优先