题目描述
使用插入排序对链表进行排序。
Sort a linked list using insertion sort.
示例1
输出
复制{2,3,4}
// 插入排序就是不断的向一个已经排序的列表中(此处为代码中的sortedList)添加新的节点,并且保证添加节点后的列表仍然有序。
// 一开始的时候sortedList为空,需要遍历输入链表(也就是未排序链表,此处为形参head)的每一个节点,每遍历一个,sortedList加一个。
// cur代表的就是你当前要加入sortedlist的节点。cur要插入的位置在sortedList的哪里呢?就是此处代码中node的后面。 经过这么一轮,一个节点就被加入到了sortlist。之后同理。 /**
* Definition
for
singly-linked list.
*
struct
ListNode {
*
int
val;
* ListNode *next;
* ListNode(
int
x) : val(x), next(NULL) {}
* };
*/
class
Solution {
public
:
ListNode *insertionSortList(ListNode *head) {
if
(head==nullptr || head->next==nullptr)
return
head;
//在插入时,有可能需要在链表头插入,为了方便,新建立个链表
ListNode sortedList(0);
ListNode *cur=head;
while
(cur){
//因为cur的指向可能会改变,所以要预先存下cur的next,以备在下次循环时使用
ListNode *next=cur->next;
//node代表排序数组的当前节点
//从前向后遍历排序数组的每一个节点,和当前未排序数组中的节点做比较
ListNode* node=&sortedList;
while
(node->next!=nullptr && node->next->val<cur->val)
//以为第一个元素是0,所以从next开始
{
node=node->next;
}
cur->next=node->next;
node->next=cur;
cur=next;
}
return
sortedList.next;
}
};