记录链表快速排序

思路就结合力扣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;
    
        }
}
全部评论

相关推荐

兄弟们你们进大厂靠的是什么项目啊
DOTPHTP:课设改。其实项目什么的如果不是实习里面的生产项目的话,建议✍️那种自己想要做的。突出个人自驱力,而不是为了找工作不得不随波逐流这种
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
06-20 14:01
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
1
1
分享

创作者周榜

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