import java.util.Arrays;
import java.util.List;
import java.util.PriorityQueue;
/*
class ListNode
{
ListNode next;
int val;
ListNode(int x)
{
val = x;
}
}
*/
//k路归并问题
public class MergKSortedLists { //二路归并,这个算法时间复杂度o(2n)
public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
ListNode dumy = new ListNode(0);
ListNode head = dumy;
while (l1 != null && l2 != null) {
if (l1.val < l2.val) {
dumy.next = l1;
l1 = l1.next;
} else {
dumy.next = l2;
l2 = l2.next;
}
dumy = dumy.next;
}
if (l1 == null) {
dumy.next = l2;
}
if (l2 == null) {
dumy.next = l1;
}
return head.next;
}
//利用二路归并进行k路归并,时间复杂度o(2kn),leetcode显示time limits exceeds
public ListNode mergeKLists1(ListNode[] lists)
{
if(lists.length == 0)
{
return null;
}
ListNode head = lists[0];
for(int i = 1; i < lists.length; i ++)
{
head = mergeTwoLists(head, lists[i]);
}
return head;
} //网上看到的很有意思的想法。就把ListNode当做一个整数,这道题,正好看做数组的二路归并排序,不过数组里面的元素是节点
//这种方法显然也是超时的,这种思想,看似是二路归并,其实并不是,粒度不一样。这个算法的时间复杂度也并不是O(nlgn)
public ListNode mergerKlists2(ListNode[] lists)
{
//自顶向下的二路归并,递归
if(lists.length == 0)
{
return null;
}
List<ListNode> a = Arrays.asList(lists);
return helper(a);
}
public ListNode helper(List<ListNode> lists)
{
if(lists.size() == 1)
{
return lists.get(0);
}
int len = lists.size();
int mid = len/2;
ListNode l1 = helper(lists.subList(0, mid));
ListNode l2 = helper(lists.subList(mid, len));
return mergeTwoLists(l1, l2);
} //利用PriorityQueue的特性,也很巧妙,并且AC
//算法思想是:比较所有k个数组的头一个元素,找到最小的那一个,然后取出来。
//我们在该最小元素所在的数组取下一个元素,然后重复前面的过程去找最小的那个。这样依次循环直到找到所有的元素。
public ListNode mergeKLists3(ListNode[] lists)
{
if(lists.length == 0)
return null;
//由于ListNode并没有实现comparable接口,我们必须自定义排序规则,可实现comparator接口,comparator是函数式接口
//comparable接口是在方法内的,而comparator接口是在方法外的注意区别两者
PriorityQueue<ListNode> queue = new PriorityQueue<>((o1, o2)->
{
ListNode l1 = (ListNode)o1;
ListNode l2 = (ListNode)o2;
return l1.val > l2.val ? 1 : l1.val < l2.val ? -1 : 0;
});
ListNode head = new ListNode(0);
ListNode p = head;
for (ListNode list : lists) {
queue.offer(list);
}
while(!queue.isEmpty())
{
ListNode n = queue.poll();
p.next = n;
p = p.next;
if(n.next!=null)
{
queue.offer(n.next);
}
}
return head.next;
}
}

堆排序算法后续补充。。。。

Merge k Sorted Lists, k路归并的更多相关文章

  1. 【LeetCode】【数组归并】Merge k Sorted Lists

    描述 Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexity ...

  2. 刷题23. Merge k Sorted Lists

    一.题目说明 这个题目是23. Merge k Sorted Lists,归并k个有序列表生成一个列表.难度为Hard,实际上并不难,我一次提交就对了. 二.我的解答 就是k路归并,思路很简单,实现也 ...

  3. Merge k Sorted Lists

    1. Merge Two Sorted Lists 我们先来看这个 问题: Merge two sorted linked lists and return it as a new list. The ...

  4. 【LeetCode练习题】Merge k Sorted Lists

    Merge k Sorted Lists Merge k sorted linked lists and return it as one sorted list. Analyze and descr ...

  5. Leetcode 23.Merge Two Sorted Lists Merge K Sorted Lists

    Merge Two Sorted Lists Merge two sorted linked lists and return it as a new list. The new list shoul ...

  6. [LeetCode] Merge k Sorted Lists 合并k个有序链表

    Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexity. 这 ...

  7. No.023:Merge k Sorted Lists

    问题: Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexit ...

  8. 71. Merge k Sorted Lists

    Merge k Sorted Lists Merge k sorted linked lists and return it as one sorted list. Analyze and descr ...

  9. 【leetcode】Merge k Sorted Lists

    Merge k Sorted Lists Merge k sorted linked lists and return it as one sorted list. Analyze and descr ...

随机推荐

  1. Objective-C规范注释心得——同时兼容appledoc(docset、html)与doxygen(html、pdf)的文档生成

    作者:zyl910 手工写文档是一件苦差事,幸好现在有从源码中抽取注释生成文档的专用工具.对于Objective-C来说,目前最好用的工具是appledoc和doxygen.可是这两种工具对于注释的要 ...

  2. lookcss在深夜23:32开通

    CSS在深夜23:32开通 话说 哥也耐不住寂寞搞个网站玩玩.顺便记录一些生活和学习和工作和思想和神马的点点滴滴~ 好吧 ~本来想起个名字叫涉趣.谁知道百度了一下,已经有人叫这个名字了,杯具,貌似还是 ...

  3. golang 热更新技巧 负载均衡才是正道啊

    golang plugin热更新尝试 - 呵大官人的鱼塘 - 开源中国 https://my.oschina.net/scgywx/blog/1796358 golang plugin热更新尝试 发布 ...

  4. Apache Tez Design

    http://tez.incubator.apache.org/ http://dongxicheng.org/mapreduce-nextgen/apache-tez/ http://dongxic ...

  5. HTTP 常见状态码

    1. 以"1"开头(临时响应) 100: Continue,请求者应当继续提出请求;表示服务端已经收到请求的一部分,正在等待其余部分; 101: Switching Protoco ...

  6. django--mysql设置

    mysql基本配置 'default': { 'ENGINE': 'django.db.backends.mysql', 'HOST': '127.0.0.1', 'PORT': 3306, 'USE ...

  7. Android学习七---Hello OpenCV samples

    创建一个能够使用OpenCV JavaCameraView的应用程序来了解基于OpenCV java API 的应用程序的开发流程.有了Android的基础,在程序中需要修改的几个地方1.activi ...

  8. Tornado的基本知识

    Tornado是FriendReed使用的可扩展的非阻塞式的web服务器及其相关工具的开源版本. 这个框架看起来有些像web.py或者Google的webapp,不过为了能有效利用非阻塞服务器环境,这 ...

  9. mysql的-F与master-data理解(一个小型的big-log恢复)

    例子: 使用mysqlbin-log恢复,有两种情况,一个是停数据库,一个是不停 在不停数据库的情况下,为了防止新的写入,需要将bin-log切割,然后新的数据会保存在新的bin-log里面 在此之前 ...

  10. PL/SQL编程—控制语句

      SQL> create or replace procedure sp_pro5(id_in varchar2) is v_sal mytest.salary%type; begin sel ...