[LintCode] 链表插入排序

 1 /**
 2  * Definition of ListNode
 3  * class ListNode {
 4  * public:
 5  *     int val;
 6  *     ListNode *next;
 7  *     ListNode(int val) {
 8  *         this->val = val;
 9  *         this->next = NULL;
10  *     }
11  * }
12  */
13 class Solution {
14 public:
15     /**
16      * @param head: The first node of linked list.
17      * @return: The head of linked list.
18      */
19     ListNode *insertionSortList(ListNode *head) {
20         // write your code here
21         ListNode* new_head = new ListNode(0);
22         new_head -> next = head;
23         ListNode* pre = new_head;
24         ListNode* cur = head;
25         while (cur) {
26             if (cur -> next && cur -> next -> val < cur -> val) {
27                 while (pre -> next && pre -> next -> val < cur -> next -> val)
28                     pre = pre -> next;
29                 /* Insert cur -> next after pre. */
30                 ListNode* temp = pre -> next;
31                 pre -> next = cur -> next;
32                 cur -> next = cur -> next -> next;
33                 pre -> next -> next = temp;
34                 /* Move pre back to the starting node. */
35                 pre = new_head;
36             }
37             else cur = cur -> next;
38         }
39         ListNode* res = new_head -> next;
40         delete new_head;
41         return res;
42     }
43 };

 

转载于:https://www.cnblogs.com/jcliBlogger/p/4609135.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值