利用链表实现可合并堆(算法导论第三版思考题10-2) a 链表已排序 创建一个空堆: Θ(1) 插入:Θ(n),插入后依然保持排序 最小值:Θ(1),第一位便是 取最小值:Θ(1) 合并:Θ(n),可以修改插入排序或者用归并排序的合并过程实现 b 链表树为排序的 创建一个空堆: Θ(1) 插入:Θ(1) 最小值:Θ(n),循环遍历 取最小值:Θ(n),循环遍历 合并:Θ(1),如果不考虑深拷贝问题,考虑的话Θ(n)复制数据 c 链表树未排序的,且待合并的动态合集是不相交的 同b 本人写的链表 List全部代码链接地址 仅供参考,里面的时间复杂度度比上面写的要高,因为要考虑到数据安全等问题。