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

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;
    }
}
posted @ 2018-07-01 23:04  ACBingo  阅读(123)  评论(0编辑  收藏  举报