[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 };
复制代码

 

posted @   jianchao-li  阅读(260)  评论(0编辑  收藏  举报
编辑推荐:
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
· ASP.NET Core 模型验证消息的本地化新姿势
阅读排行:
· 开发的设计和重构,为开发效率服务
· ThreeJs-16智慧城市项目(重磅以及未来发展ai)
· 从零开始开发一个 MCP Server!
· .NET 原生驾驭 AI 新基建实战系列(一):向量数据库的应用与畅想
· Ai满嘴顺口溜,想考研?浪费我几个小时
点击右上角即可分享
微信分享提示