美文网首页
合并 k 个排序链表

合并 k 个排序链表

作者: 小白学编程 | 来源:发表于2019-07-11 17:32 被阅读0次

合并 k 个排序链表,返回合并后的排序链表。请分析和描述算法的复杂度。

示例:

输入:
[
1->4->5,
1->3->4,
2->6
]
输出: 1->1->2->3->4->4->5->6

思路

先合并两条链表,以此类推,合并k - 1次

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
class Solution {
    public ListNode mergeKLists(ListNode[] lists) {
        if (lists == null || lists.length == 0) {
            return null;
        }
        ListNode mergeList = lists[0];
        for (int i = 1; i < lists.length; i++) {
            mergeList = merge(mergeList, lists[i]);
        }
        return mergeList;
    }
    //合并两条有序链表
    public static ListNode merge(ListNode list1, ListNode list2) {
        ListNode dumy = new ListNode(0);
        ListNode temp = dumy;
        while (list1 != null && list2 != null) {
            ListNode node;
            if (list1.val < list2.val) {
                node = new ListNode(list1.val);
                list1 = list1.next;
               
            } else {
                node = new ListNode(list2.val);
                list2 = list2.next;
                
            }
            
             temp.next = node;
            temp = temp.next;
            
        }
        
        temp.next = (list1 == null) ? list2 : list1;
        
//         while (list1 != null) {
//             ListNode node = new ListNode(list1.val);
//             temp.next = node;
//             temp = temp.next;
//             list1 = list1.next;
            
//         }
        
//         while (list2 != null) {
//             ListNode node = new ListNode(list2.val);
//             temp.next = node;
//             temp = temp.next;
//             list2 = list2.next;
//         }
        
        return dumy.next;
    }
}

相关文章

  • leecode刷题(27)-- 合并k个排序链表

    leecode刷题(27)-- 合并k个排序链表 合并k个排序链表 合并 k 个排序链表,返回合并后的排序链表。请...

  • ARTS第五周2020620

    Algorithm 合并K个排序链表 合并 k 个排序链表,返回合并后的排序链表。请分析和描述算法的复杂度。 示例...

  • 合并K个排序链表【LeetCode:23】

    题目: 合并K个排序链表 合并 k 个排序链表,返回合并后的排序链表。请分析和描述算法的复杂度。 示例: 输入: ...

  • Swift - LeetCode - 合并K个排序链表

    题目 合并K个排序链表 问题: 合并 k 个排序链表,返回合并后的排序链表。请分析和描述算法的复杂度。 解题思路:...

  • LeetCode:合并K个排序链表

    合并K个排序链表(困难) 题目叙述: 合并 k 个排序链表,返回合并后的排序链表。请分析和描述算法的复杂度。 示例...

  • LeetCode-23-合并K个有序链表

    LeetCode-23-合并K个有序链表 题目 合并 k 个排序链表,返回合并后的排序链表。请分析和描述算法的复杂...

  • 23. 合并K个排序链表

    23.合并K个排序链表 合并k个排序链表,返回合并后的排序链表。请分析和描述算法的复杂度。 示例: 输入:[ 1-...

  • 【算法】合并K个排序链表

    合并K个排序链表 描述 合并 k 个排序链表,返回合并后的排序链表。 解题思路 1.将所有节点添加到数组中,对数组...

  • LeetCode 专题 :分治算法

    LeetCode 第 23 题:归并多个有序链表 传送门:23. 合并K个排序链表。 合并 k 个排序链表,返回合...

  • 【LeetCode】23.合并K个排序链表

    题目描述 23.合并K个排序链表 合并k个排序链表,返回合并后的排序链表。请分析和描述算法的复杂度。 题目解析 方...

网友评论

      本文标题:合并 k 个排序链表

      本文链接:https://www.haomeiwen.com/subject/jjgdkctx.html