2025年--Lc197-077. 排序链表(链表,尾插法)--Java版

1.题目


2.思路

(1)计算节点数

(2)创建数组存储链表的节点值

(3)对数组进行排序

(4)利用尾插法生成链表

3.代码实现

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode sortList(ListNode head) {
        //如果是空链表或者只有一个链表节点,我们直接返回
        if(head==null||head.next==null)
        {
            return head;
        }
        int num=0;
        ListNode tmp=head;
        while(tmp!=null)
        {
            num++;
            tmp=tmp.next;
        }
        //创建1个新数组
        int[] nums=new int[num];
        int i=0;
        tmp=head;
        while(tmp!=null)
        {
            nums[i]=tmp.val;
            tmp=tmp.next;
            i++;
        }
        //对数组进行排序
        Arrays.sort(nums);
        //因为nums是升序排序,所以构造链表是尾插法
        //链表的头指针(第一个节点)。最终返回它。
        ListNode begin=null;
        ListNode end=null;
        for(int j=0;j<num;j++)
        {
            if(begin==null)
            {
            begin=new ListNode(nums[j]);// 创建第一个节点
            end=begin;// 此时头节点也是尾节点
            }
            else{
            ListNode p=new ListNode(nums[j]);// // 新节点
            end.next=p;// 把新节点接在"尾巴"后面
            p.next=null;// 新节点的 next 指向 null
            end=p;// 更新尾指针,指向新的尾节点
        }


    }
    return begin;
}
}
相关推荐
海边的Kurisu4 分钟前
苍穹外卖日记 | Day1 苍穹外卖概述、开发环境搭建、接口文档
java
C雨后彩虹4 小时前
任务最优调度
java·数据结构·算法·华为·面试
heartbeat..4 小时前
Spring AOP 全面详解(通俗易懂 + 核心知识点 + 完整案例)
java·数据库·spring·aop
Jing_jing_X4 小时前
AI分析不同阶层思维 二:Spring 的事务在什么情况下会失效?
java·spring·架构·提升·薪资
元Y亨H6 小时前
Nacos - 服务发现
java·微服务
微露清风6 小时前
系统性学习C++-第十八讲-封装红黑树实现myset与mymap
java·c++·学习
dasi02276 小时前
Java趣闻
java
阿波罗尼亚7 小时前
Tcp SSE Utils
android·java·tcp/ip
一条大祥脚7 小时前
26.1.9 轮廓线dp 状压最短路 构造
数据结构·c++·算法
susu10830189117 小时前
springboot3.5.8整合minio8.5.9
java·springboot