首页 > 编程语言 > 详细

[leetcode] 23. 合并K个排序链表

时间:2018-07-01 23:43:12      阅读:296      评论:0      收藏:0      [点我收藏+]

23. 合并K个排序链表

这个题算是考察代码功底吧,基本功,对变量与引用的理解。

不多说了,思路跟第21题基本一致,只不过从两个换成了多个

class Solution {
    public ListNode mergeKLists(ListNode[] lists) {

        List<ListNode> listNodes = new ArrayList<>(Arrays.asList(lists));

        ListNode ans = new ListNode(Integer.MAX_VALUE);
        ListNode k = ans;

        while (not_finish(listNodes)) {
            int p = choose(listNodes);
            ListNode pNode = listNodes.get(p);
            k.next = pNode;
            pNode = pNode.next;
            listNodes.remove(p);
            listNodes.add(pNode);
            k = k.next;
        }

        return ans.next;
    }

    private int choose(List<ListNode> lists) {
        int min = Integer.MAX_VALUE;
        int p = -1;
        for (int i = 0; i < lists.size(); i++) {
            if (min >= lists.get(i).val) {
                min = lists.get(i).val;
                p = i;
            }
        }
        return p;
    }

    private boolean not_finish(List<ListNode> lists) {
        for (int i = lists.size() - 1; i >= 0; i--) {
            if (lists.get(i) == null) {
                lists.remove(i);
            }
        }
        return lists.size() > 0;
    }
}

[leetcode] 23. 合并K个排序链表

原文:https://www.cnblogs.com/acbingo/p/9251717.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!