博客
关于我
Algorithms : Sort linklist
阅读量:366 次
发布时间:2019-03-04

本文共 4373 字,大约阅读时间需要 14 分钟。

Sort a linked list in O(n log n) time using constant space complexity.

 

/** * Definition for singly-linked list. * struct ListNode { *     int val; *     ListNode *next; *     ListNode(int x) : val(x), next(NULL) {} * }; */class Solution {public:    ListNode* sortList(ListNode* head) {        if (head == nullptr || head->next == nullptr) return head;                ListNode * pivot = head, * small = nullptr, * large = nullptr, *sp = nullptr, *lp = nullptr;        head = head->next;        while(head) {            if(head->val < pivot->val) {                if (small == nullptr) small = head;                else sp->next = head;                sp = head;            } else {                if (large == nullptr) large = head;                else lp->next = head;                lp = head;            }            head = head->next;        }        if(sp) sp->next = nullptr;        if(lp) lp->next = nullptr;                // sort the sub list.        sp = sortList(small);        lp = sortList(large);                // merge the sub list.        if(sp)  {            head = sp;            // seek to the last node.            while(sp->next)                sp = sp->next;            sp->next = pivot;        } else {            head = pivot;        }                pivot->next = lp;        return head;    }};

if we only change the value. it will improve a some time complexity.

/** * Definition for singly-linked list. * struct ListNode { *     int val; *     ListNode *next; *     ListNode(int x) : val(x), next(NULL) {} * }; */class Solution {private:    ListNode * partition(ListNode * head, ListNode * tail) {        if(head == tail || head->next == nullptr) return head;        int pivot = head->val;        ListNode * slow = head, *fast = head->next;        while(fast && fast != tail) {            if (fast->val < pivot) {                slow = slow->next;                swap(slow->val, fast->val);            }            fast = fast->next;        }        // swap the pivot        swap(slow->val, head->val);        return slow;    }        void quicksort(ListNode * head, ListNode * tail) {        if(head == tail || head->next == nullptr) return;                ListNode * pivot = partition(head, tail);        quicksort(head, pivot);        quicksort(pivot->next, tail);    }public:    ListNode* sortList(ListNode* head) {        quicksort(head, nullptr);        return head;    }};

 

if we do a non-recursive merge sort. the effeciency will be time O(NlogN), and the space with O(1).

/** * Definition for singly-linked list. * struct ListNode { *     int val; *     ListNode *next; *     ListNode(int x) : val(x), next(NULL) {} * }; */class Solution {private:    // from head->@->@->@->null to    // head->@->@->null  current->@->null    ListNode * cut(ListNode * head, int n) {        if (head == nullptr) return head;        ListNode * p = head;        while(--n && p) {            p = p->next;        }        if (p == nullptr) return nullptr;        ListNode * next = p->next;        // cut the current node        p->next = nullptr;        return next;    }        // merge two linklist and return the header    ListNode * merge(ListNode * l, ListNode * r) {        ListNode dummyHead(0);        ListNode * p = &dummyHead;                while(l && r) {            if(l->val < r->val) {                p->next = l;                p = l;                l = l->next;            } else {                p->next = r;                p = r;                r = r->next;            }        }        p->next = l ? l : r;        return dummyHead.next;    }    public:    ListNode* sortList(ListNode* head) {        ListNode dummyHead(0);        dummyHead.next = head;                int length = 0;        while(head) {            head = head->next;            ++length;        }                for(int size = 1; size < length; size <<= 1) {            ListNode * cur = dummyHead.next;            ListNode * p = &dummyHead;                        while(cur) {                ListNode * left = cur;                ListNode * right = cut(cur, size);                cur = cut(right, size);                                p->next = merge(left, right);                // seek to the end.                while(p->next) {                    p = p->next;                }                            }        }                return dummyHead.next;            }};

 

转载地址:http://upbg.baihongyu.com/

你可能感兴趣的文章
Nginx配置ssl实现https
查看>>
nginx配置ssl证书https解决公网ip可以访问但是域名不行的问题
查看>>
Nginx配置TCP代理指南
查看>>
NGINX配置TCP连接双向SSL
查看>>
Nginx配置——不记录指定文件类型日志
查看>>
nginx配置一、二级域名、多域名对应(api接口、前端网站、后台管理网站)
查看>>
nginx配置中的服务器名称
查看>>
Nginx配置代理解决本地html进行ajax请求接口跨域问题
查看>>
nginx配置全解
查看>>
Nginx配置参数中文说明
查看>>
Nginx配置后台网关映射路径
查看>>
nginx配置域名和ip同时访问、开放多端口
查看>>
Nginx配置多个不同端口服务共用80端口
查看>>
Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
查看>>
Nginx配置如何一键生成
查看>>
Nginx配置实例-动静分离实例:搭建静态资源服务器
查看>>
Nginx配置实例-反向代理实例:根据访问的路径跳转到不同端口的服务中
查看>>
Nginx配置实例-反向代理实现浏览器请求Nginx跳转到服务器某页面
查看>>
Nginx配置实例-负载均衡实例:平均访问多台服务器
查看>>
Nginx配置文件nginx.conf中文详解(总结)
查看>>