• 单链表的插入排序


    1. 插入排序的基本思想:将一个节点插入到一个有序的序列中。对于链表而言,要依次从待排序的链表中取出一个节点插入到已经排好序的链表中,也就是说,在单链表插入排序的过程中,原链表会截断成两部分,一部分是原链表中已经排好序的节点,另一部分是原链表中未排序的节点,这样就需要在排序的过程中设置一个当前节点,指向原链表未排序部分的第一个节点。

    注意单链表插入排序和数组插入排序的不同:数组插入排序是从排好序的部分的最后一个节点往前找,找到第一个比它小的数,然后插到其后面;而单链表只能从前往后遍历,找到第一个比当前节点大的值结束,因此在遍历已经排好序的链表部分的时候,需要两个指针,一个指针用于往前遍历(该指针假设为遍历指针),一个指针用于记录遍历指针指向的当前节点的前一个节点(该指针假设为遍历指针),这样当遍历指针找到第一个比待插入节点的值大的节点的时候,就可以将待插入节点插入到记录指针的后面。(之所以使用两个指针,是因为单链表不能反指)

         插入排序分两种情况,一种是当前节点的值比已经排好序的尾节点的值大,则直接将当前节点挂在已排序的节点即可;一种是当前节点值比已经排好序的尾节点的值小,则需将已排好序的链表部分从头到尾遍历,找到第一个比当前节点值大的节点,插入到其前面即可。因为可能待插入的节点可能在第一个节点的前面,因此另外创建一个头结点,指向已经排好序的链表的第一个节点。这样可以每次插入新的节点的时候,将上面所提到的记录节点初始化为新创建的头结点,这样便于在第一个节点前面插入新节点。

     1 class Solution
     2 
     3 {
     4 
     5 public:
     6 
     7     ListNode *insertionSortList(ListNode *head)
     8 
     9     {
    10 
    11         if(head==NULL || head->next==NULL) return head;
    12 
    13         ListNode *cur=head;
    14 
    15         ListNode *helper=new ListNode(0);
    16 
    17         ListNode *pre;
    18 
    19         while(cur)
    20 
    21         {
    22 
    23             ListNode *next=cur->next;
    24 
    25             pre=helper;
    26 
    27             while(pre->next!=NULL && pre->next->val<cur->val)
    28 
    29             {
    30 
    31                 pre=pre->next;
    32 
    33             }
    34 
    35             cur->next=pre->next;
    36 
    37             pre->next=cur;
    38 
    39             cur=next;
    40 
    41         }
    42 
    43         return helper->next;
    44 
    45     }
    46 
    47  
    48 
    49 }  
  • 相关阅读:
    第一期知识点
    如何正确地停止一个线程?
    JVM知识点总览-高级Java工程师面试必备
    常见GC算法,CMS以及G1的垃圾回收过程,CMS的各个阶段哪两个是Stop the world的,CMS会不会产生碎片,G1的优势。
    深入理解分布式事务,高并发下分布式事务的解决方案
    JVM中的逃逸分析
    JVM内存初学 堆、栈、方法区
    JVM方法栈的工作过程,方法栈和本地方法栈有什么区别。
    JVM的基本结构和JVM的内存结构
    一致性hash算法应用场景、详解与实现(JAVA)
  • 原文地址:https://www.cnblogs.com/yuanshuang/p/5479242.html
Copyright © 2020-2023  润新知