标签:log div 排序 选择 思路 代码 font 插入排序 链表
Sort a linked list using insertion sort.
链表的插入排序和数组的插入排序略有不同。以链表4->2->3->1->5为例,为方便操作添加一个头节点-1,此时链表为-1->4->2->3->1->5。基本思路为一次选择前后两个节点,若后节点大于前节点则不断向后循环,若后节点小于前节点则取出后节点,并插入到头节点和前节点之间的位置。
举例说明:
1 class Solution { 2 public: 3 ListNode* insertionSortList(ListNode* head) { 4 if (head == NULL || head->next == NULL) 5 return head; 6 ListNode *newhead = new ListNode(-1); 7 newhead->next = head; 8 ListNode *cur = head; 9 ListNode *nextnode = head->next; 10 while (nextnode != NULL) { 11 if (cur->val <= nextnode->val) { 12 nextnode = nextnode->next; 13 cur = cur->next; 14 } else { 15 ListNode *temp = nextnode; 16 cur->next = nextnode->next; 17 nextnode = nextnode->next; 18 19 ListNode *pre = newhead; 20 ListNode *insert = newhead->next; 21 while (insert->val <= temp->val) { 22 pre = insert; 23 insert = insert->next; 24 } 25 pre->next = temp; 26 temp->next = insert; 27 } 28 } 29 return newhead->next; 30 } 31 };
标签:log div 排序 选择 思路 代码 font 插入排序 链表
原文地址:http://www.cnblogs.com/sindy/p/6935239.html