LeetCode:Sort List
Title:
Sort a linked list in O(n log n) time using constant space complexity.
思路:考虑快速排序和归并排序,但是我的快速排序超时了
ListNode* sortList(ListNode* head) {
if (!head)
return NULL;
int m_val = head->val;
ListNode* left = NULL,*right = NULL;
ListNode* p_left = NULL,*p_right = NULL;
ListNode* p = head->next;
if (p == NULL)
return head;
while (p){
if (p->val < m_val){
if (left == NULL)
left = p;
else
p_left->next = p;
p_left = p;
}else{
if (right == NULL)
right = p;
else
p_right->next = p;
p_right = p;
}
p = p->next;
}
if (p_left)
p_left->next = NULL;
if (p_right)
p_right->next = NULL;
ListNode* sorted_left = sortList(left);
ListNode* sorted_right = sortList(right);
ListNode *sorted = new ListNode();
p = sorted_left;
ListNode* p_cur = sorted;
while (p){
p_cur->next = p;
p_cur = p;
p = p->next;
}
p_cur->next = head;
p_cur = head;
p_cur->next = sorted_right;
return sorted->next;
}
归并排序。两种思路,一个得到全部长度之后,进行。另一种使用快慢指针
class Solution {
private:
int len(ListNode* head){
int l = ;
ListNode*p = head;
while (p){
l++;
p = p->next;
}
return l;
}
public:
ListNode* sortList(ListNode* head){
if (head == NULL)
return NULL;
int length = len(head);
return sort(head,length);
}
ListNode* sort(ListNode*& head,int length){
if (length == ){
ListNode* t = head;
head = head->next;//这个地方要注意。同时使用指针引用的目的是让head一直往后。因为总是左边的先走,所以到sort(head,length-length/2)时head刚好就是那个位置。
t->next = NULL;
return t;
}
ListNode*left = sort(head,length/);
ListNode*right = sort(head,length-length/);
return merge(left,right);
}
ListNode* merge(ListNode* left,ListNode* right){
ListNode* head = new ListNode();
ListNode* p = head;
while (left && right){
if (left->val < right->val){
p->next = left;
p = left;
left = left->next;
}else{
p->next = right;
p = right;
right = right->next;
}
}
while (left){
p->next = left;
p = left;
left = left->next;
}
while (right){
p->next = right;
p = right;
right = right->next;
}
return head->next;
}
}
class Solution {
public:
ListNode *sortList(ListNode *head) {
if(!head||!head->next)
return head;
return mergeSort(head);
}
ListNode * mergeSort(ListNode *head){
if(!head||!head->next) //just one element
return head;
ListNode *p=head, *q=head, *pre=NULL;
while(q&&q->next!=NULL){
q=q->next->next;
pre=p;
p=p->next; //divide into two parts
}
pre->next=NULL;
ListNode *lhalf=mergeSort(head);
ListNode *rhalf=mergeSort(p); //recursive
return merge(lhalf, rhalf); //merge
}
ListNode * merge(ListNode *lh, ListNode *rh){
ListNode *temp=new ListNode();
ListNode *p=temp;
while(lh&&rh){
if(lh->val<=rh->val){
p->next=lh;
lh=lh->next;
}
else{
p->next=rh;
rh=rh->next;
}
p=p->next;
}
if(!lh)
p->next=rh;
else
p->next=lh;
p=temp->next;
temp->next=NULL;
delete temp;
return p;
}
};
LeetCode:Sort List的更多相关文章
- [LeetCode] Wiggle Sort II 摆动排序
Given an unsorted array nums, reorder it such that nums[0] < nums[1] > nums[2] < nums[3]... ...
- [LeetCode] Insertion Sort List 链表插入排序
Sort a linked list using insertion sort. 链表的插入排序实现原理很简单,就是一个元素一个元素的从原链表中取出来,然后按顺序插入到新链表中,时间复杂度为O(n2) ...
- LeetCode之Sort List
称号:Sort a linked list in O(n log n) time using constant space complexity. 对一个单链表进行排序,要求时间复杂度为O(n log ...
- 【LeetCode】 sort list 单清单归并
称号:Sort a linked list in O(n log n) time using constant space complexity. 思路:要求时间复杂度O(nlogn) 知识点:归并排 ...
- C#版 - LeetCode 148. Sort List 解题报告(归并排序小结)
leetcode 148. Sort List 提交网址: https://leetcode.com/problems/sort-list/ Total Accepted: 68702 Total ...
- [LeetCode] Wiggle Sort II 摆动排序之二
Given an unsorted array nums, reorder it such that nums[0] < nums[1] > nums[2] < nums[3]... ...
- 待字闺中之快排单向链表;leetcode之Sort List
题目来源.待字闺中.原创@陈利人 .欢迎大家继续关注微信公众账号"待字闺中" 分析:思路和数据的高速排序一样,都须要找到一个pivot元素.或者节点. 然后将数组或者单向链表划分为 ...
- LeetCode:二进制手表【401】
LeetCode:二进制手表[401] 题目描述 二进制手表顶部有 4 个 LED 代表小时(0-11),底部的 6 个 LED 代表分钟(0-59). 每个 LED 代表一个 0 或 1,最低位在右 ...
- LeetCode:组合总数II【40】
LeetCode:组合总数II[40] 题目描述 给定一个数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合. candi ...
随机推荐
- Unity3d 接入 移动MM支付SDK(2.3) 全攻略
原地址:http://blog.csdn.net/dingxiaowei2013/article/details/26842177 先将例程运行起来 下载例程(csdn积分不够上传不了,只能用百度网盘 ...
- 数据库批量插入数据的shell脚本
测试用,先来一个简单的,这个是国产神通数据库的,用isql命令: !/bin/bash == "-h" ] then echo "USAGE: $0 table_name ...
- gcd 最大公约数 模版!
1: #define ll long long ll gcd(ll a,ll b) { ) { return b; }else { return gcd(b % a,a); } } 2: int64 ...
- POJ 3228 Gold Transportation(带权并查集,好题)
参考链接:http://www.cnblogs.com/jiaohuang/archive/2010/11/13/1876418.html 题意:地图上某些点有金子,有些点有房子,还有一些带权路径,问 ...
- Intent(二)
以Android高级编程一书中的一个例子为例: 1, 创建一个ContactPicker项目,其中包含一个ContactPicker Activity package com.paad.contact ...
- **CI两种方式查询所返回的结果数量
区别:第一个是有条件的:第二个没有条件 $this->db->count_all_results(); 允许你获得某个特定的Active Record查询所返回的结果数量.可以使用Acti ...
- ORA-04052\ ORA-00604\ORA-12154
ORA-04052: error occurred when looking up remote object TBCS.SUBS_PRIVILEGE@DD2A ORA-00604: error oc ...
- 典型重构3 (Try/Catch)
Try/Catch 块过多 public Customer GetCustomer(string customerId) { try { var command = new SqlCommand(); ...
- kindeditor.net应用
1.网址:http://kindeditor.net/docs/usage.html
- 使用ajax()方法加载服务器数据
使用ajax()方法加载服务器数据 使用ajax()方法是最底层.功能最强大的请求服务器数据的方法,它不仅可以获取服务器返回的数据,还能向服务器发送请求并传递数值,它的调用格式如下: jQuery.a ...