博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【python/Hard/23】Merge k Sorted Lists
阅读量:2171 次
发布时间:2019-05-01

本文共 1027 字,大约阅读时间需要 3 分钟。

题目

这里写图片描述

基本思路

借助python的heapq模块,来创建一个小根堆,将所有节点放入这个小根堆中,然后依次将堆顶元素组合成结果链表

  • heapq方法
heappush(heap, x)       将 x 入堆heappop(heap)           将堆属性中的最小元素弹出   heapify(heap)           将 heap 属性强制应用到任意一个列表heapreplace(heap, x)    将堆中的最小的元素弹出,同时将 x 入堆merge()                 多个堆合并         nlargest(n, iter)       返回 iter 中的第 n 大的元素nsmallest(n, iter)      返回 iter 中的第 n 小的元素

将所有链表的节点 push 到堆中,每次把最小的 pop 出来

实现代码

# Definition for singly-linked list.# class ListNode:#     def __init__(self, x):#         self.val = x#         self.next = Noneimport heapqclass Solution(object):    def mergeKLists(self, lists):        """        :type lists: List[ListNode]        :rtype: ListNode        """        heap = []        for node in lists:            while node:                heapq.heappush(heap, node.val)                node = node.next        temp = ListNode(-1)        head = temp        while heap:            smallestNodeVal = heapq.heappop(heap)            temp.next = ListNode(smallestNodeVal)            temp = temp.next        return head.next
你可能感兴趣的文章
开源Faac实现PCM编码AAC
查看>>
Windows下wave API 音频采集
查看>>
借船过河:一个据说能看穿你的人性和欲望的心理测试
查看>>
AndroidStudio 导入三方库使用
查看>>
Ubuntu解决gcc编译报错/usr/bin/ld: cannot find -lstdc++
查看>>
解决Ubuntu14.04 - 16.10版本 cheese摄像头灯亮却黑屏问题
查看>>
解决Ubuntu 64bit下使用交叉编译链提示error while loading shared libraries: libz.so.1
查看>>
Android Studio color和font设置
查看>>
Python 格式化打印json数据(展开状态)
查看>>
Centos7 安装curl(openssl)和libxml2
查看>>
Centos7 离线安装RabbitMQ,并配置集群
查看>>
Centos7 or Other Linux RPM包查询下载
查看>>
运行springboot项目出现:Type javax.xml.bind.JAXBContext not present
查看>>
Java中多线程向mysql插入同一条数据冲突问题
查看>>
Idea Maven项目使用jar包,添加到本地库使用
查看>>
FastDFS集群架构配置搭建(转载)
查看>>
HTM+CSS实现立方体图片旋转展示效果
查看>>
FFmpeg 命令操作音视频
查看>>
问题:Opencv(3.1.0/3.4)找不到 /opencv2/gpu/gpu.hpp 问题
查看>>
目的:使用CUDA环境变量CUDA_VISIBLE_DEVICES来限定CUDA程序所能使用的GPU设备
查看>>