题解 | #链表排序#

链表排序

http://www.nowcoder.com/practice/d75c232a0405427098a8d1627930bea6

public ListNode sortList(ListNode head) {
if( head == null ){
return head;
}

        List<ListNode> list = new LinkedList<ListNode>();

        ListNode node = head;
        while( node!=null ){
           list.add(node);
           node = node.next;
        }


        list.sort(new Comparator<ListNode>() {

            @Override
            public int compare(ListNode o1, ListNode o2) {
                return o1.val > o2.val ? 1 : (o1.val == o2.val ? 0 : -1);
            }
        });
    head = new ListNode(0);
    ListNode r = head;
    for (ListNode n : list) {
        System.out.print(n.val + " ");
        r.next = n;
        r = n;
    }
    r.next = null;

    return head.next;
}
全部评论

相关推荐

程序员牛肉:牛逼,超级击鼓传花呢隔着块。暑期的时候我也是这样,一个月了offer传到我手上了
点赞 评论 收藏
分享
10-28 10:48
已编辑
门头沟学院 Java
孩子我想要offer:发笔试后还没笔试把我挂了,然后邮箱一直让我测评没测,后面不知道干嘛又给我捞起来下轮笔试,做完测评笔试又挂了😅
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务