[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 };
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
· ASP.NET Core 模型验证消息的本地化新姿势
· 开发的设计和重构,为开发效率服务
· ThreeJs-16智慧城市项目(重磅以及未来发展ai)
· 从零开始开发一个 MCP Server!
· .NET 原生驾驭 AI 新基建实战系列(一):向量数据库的应用与畅想
· Ai满嘴顺口溜,想考研?浪费我几个小时