记录链表快速排序

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

相关推荐

不愿透露姓名的神秘牛友
06-19 14:46
和女友两个人马上毕业,现在我在鹅实习995,周六日偶尔也去北京;她在北京金融007,经常忙到后半夜,周末也没啥休息机会两个人现在都不咋聊天了,一句话隔半小时甚至半天才回。&nbsp;她是个很优秀的妹子,工作也很努力,是值得学习一辈子的人。我在努力工作求转正,即便不行至少赚到了一段不错的实习经历。已经异地了半年,接下来可能还会持续是这个状态。我们都算是对方重要的人,只是感觉看上去不是很有未来的样子。希望牛友们给点的鼓励
梦旅奇缘:很难。异地首先就已经很难了,加上妹子是金融行业,忙碌高压,对情感需求很高,而且见惯纸醉金迷,你的很多优势在她那里可能就不算什么了。这种情况下,在她们那里遇到一个能及时照顾她的人,即使那人可能很多条件不如你,你也有可能被分手。 说白了,两个卷王就不太适合在一起。因为卷王最大的优势,在另一个卷王那里就不算优势了。
点赞 评论 收藏
分享
05-30 12:03
山西大学 C++
offer来了我跪着接:不是骗子,等到测评那一步就知道为啥这么高工资了
点赞 评论 收藏
分享
喜欢飞来飞去的雪碧在刷代码:可以试一试字节
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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