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;
}
}
相关推荐
GoodStudyAndDayDayUp14 分钟前
RUO-VUE-PRO权限关联sql
java·数据库·sql
⑩-29 分钟前
RabbitMQ 架构和工作原理?RabbitMQ 延迟队列如何实现?
java·分布式·架构·rabbitmq
子非鱼@Itfuture30 分钟前
try-catch和try-with-resources区别是什么?try{}catch(){}和try(){}catch(){}有什么好处?
java·开发语言
Morwit44 分钟前
*【力扣hot100】 215. 数组中的第K个最大元素
数据结构·c++·算法·leetcode·职场和发展
ab1515171 小时前
3.20二刷基础121、127,完成进阶61、62
数据结构·算法·排序算法
I_LPL1 小时前
day58 代码随想录算法训练营 图论专题11
数据结构·算法·图论
Nyarlathotep01131 小时前
线程创建和Thread类
java
小比特_蓝光1 小时前
算法篇1-----双指针
数据结构·算法
阿波罗尼亚1 小时前
JDK17 新特性
java
独自破碎E1 小时前
【面试真题拆解】Spring事务机制
java·spring·面试