首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >LeetCode77|排序链表

LeetCode77|排序链表

作者头像
码农王同学
修改2020-10-14 10:35:58
修改2020-10-14 10:35:58
29000
代码可运行
举报
文章被收录于专栏:后端Coder后端Coder
运行总次数:0
代码可运行

1,问题简述

在 O(n log n) 时间复杂度和常数级空间复杂度下,对链表进行排序。

2,示例

代码语言:javascript
代码运行次数:0
运行
复制
示例 1:

输入: 4->2->1->3
输出: 1->2->3->4
示例 2:

输入: -1->5->3->4->0
输出: -1->0->3->4->5

3,题解思路

链表操作

4,题解程序

代码语言:javascript
代码运行次数:0
运行
复制

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class SortListTest2 {
    public static void main(String[] args) {
        ListNode l1 = new ListNode(4);
        ListNode l2 = new ListNode(2);
        ListNode l3 = new ListNode(1);
        ListNode l4 = new ListNode(3);
        l1.next = l2;
        l2.next = l3;
        l3.next = l4;
        ListNode listNode = sortList(l1);
        System.out.println("listNode = " + listNode);

    }

    public static ListNode sortList(ListNode head) {
        if (head == null || head.next == null) {
            return head;
        }
        List<Integer> list = new ArrayList<>();
        ListNode temp = head;
        while (temp != null) {
            list.add(temp.val);
            temp = temp.next;
        }
        Collections.sort(list);
        ListNode dummyNode = new ListNode(-1);
        ListNode tempNode = dummyNode;
        for (Integer integer : list) {
            tempNode.next = new ListNode(integer);
            tempNode = tempNode.next;
        }
        return dummyNode.next;
    }
}

5,题解程序图片版

6,总结

有的时候自己写完整道题之后,确实不知道给你们说什么了,我觉得目前我输出的内容都是常规思路题,所以你懂吧,看懂代码的可以自己单独写写就可以了,具体的解题思路真的不知道怎么描述了。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-10-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 码农王同学 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档