记录链表快速排序

思路就结合力扣147看代码

需要理清链表的前后关系

/**
 * 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 insertionSortList(ListNode head) {
    // 1. 首先判断给定的链表是否为空,若为空,则不需要进行排序,直接返回。
    if(head==null){
        return head;
    }

    //2.链表初始化
    ListNode dummyHead=new ListNode();  //引入哑节点
    dummyHead.next=head;                //目的是在head之前插入节点
    ListNode lastSorted=head;           //维护lastSorted为链表以及排好序的最后一个节点并初始化
    ListNode curr=head.next;            //维护curr为待插入的元素并初始化


    //3.插入排序
    while(curr!=null){
        if(lastSorted.val<=curr.val){   // 说明curr应该位于lastSorted之后
        lastSorted=lastSorted.next;     // 将lastSorted后移一位,curr变成新的lastSorted
        }else{                           // 否则,从链表头结点开始向后遍历链表中的节点
            ListNode prev=dummyHead;     // 从链表头开始遍历 prev是插入节点curr位置的前一个节点
            while(prev.next.val<=curr.val){     // 循环退出的条件是找到curr应该插入的位置
                prev=prev.next;        
            }
       
 // 以下三行是为了完成对curr的插入(配合题解动图可以直观看出)
        lastSorted.next=curr.next;
        curr.next=prev.next;
        prev.next=curr;

    }
    curr=lastSorted.next;  // 此时 curr 为下一个待插入的元素

     }
  // 返回排好序的链表
        return dummyHead.next;
    
        }
}
全部评论

相关推荐

10-24 11:10
山西大学 Java
若梦难了:哥们,面试挂是很正常的。我大中厂终面挂,加起来快10次了,继续努力吧。
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务