zoukankan      html  css  js  c++  java
  • sort list(给链表排序)

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

    题目要求使用O(nlogn)时间复杂度,可以考虑使用归并排序,在  merge two sorted lists 中,已经知道了将两个有序链表进行合并。这里只要在这基础上修改。

    排序算法入门之归并排序(java实现) 说了数组的归并排序,

    使用归并排序。每次要找到中间元素进行前后的排序,然后进行合并。
    合并时,数组是使用一个额外的空数组,因为使用一个数组要用到插入,数组操作插入不方便。
    对于链表合并,可以使用一个额外的链表。也可以不使用额外链表,使用两个合并链表中的一个,将合并后元素都放到该链表中,因为链表操作插入方便。

    /**
     * Definition for singly-linked list.
     * public class ListNode {
     *     int val;
     *     ListNode next;
     *     ListNode(int x) { val = x; }
     * }
     */
    class Solution {
        /**
        使用归并排序。每次要找到中间元素进行前后的排序,然后进行合并。
        合并时,数组是使用一个额外的空数组,因为使用一个数组要用到插入,数组操作插入不方便。
        对于链表合并,可以使用一个额外的链表。也可以不使用额外链表,使用两个合并链表中的一个,将合并后元素都放到该链表中,因为链表操作插入方便。
        */
        public ListNode sortList(ListNode head) {
            return mergeSort(head);
        }
        public ListNode mergeSort(ListNode head){
            if(head==null||head.next==null) return head;
            //找到中间节点,然后将链表断开,分成两个链表
            ListNode slow=head;
            ListNode fast=head;
            while(fast.next!=null&&fast.next.next!=null){
                slow=slow.next;
                fast=fast.next.next;
            }
            //将链表断开,分成两个
            ListNode head2=slow.next;
            slow.next=null;//断开
            ListNode head1=head;
            head1=mergeSort(head1);
            head2=mergeSort(head2);
            return merge(head1,head2);
            
        }
        //这里合并时,不使用额外的链表,使用l1作为保存结果,但是因为l1的第一个元素可能会发生改变,所以新建一个节点
        public ListNode merge(ListNode l1,ListNode l2){
            ListNode helper=new ListNode(0);
            helper.next=l1;
            ListNode pre=helper;//指向l1节点的前一个节点,用于插入节点到l1前面
            while(l1!=null&&l2!=null){
                if(l1.val<l2.val){
                    l1=l1.next;
                }else{
                    ListNode next=l2.next;
                    l2.next=l1;
                    pre.next=l2;
                    l2=next;
                    
                }
                pre=pre.next;
            }
            while(l2!=null){
                pre.next=l2;
                pre=pre.next;
                l2=l2.next;
            }
            return helper.next;
        }
    }
  • 相关阅读:
    socket用法以及tomcat静态动态页面的加载
    SQL2000的三种“故障还原模型”
    杀毒软件拦截的,看不懂,留作纪念
    TOMCAT如何建立两个端口或服务
    非正常关机后造成数据库 置疑 状态的解决办法
    各数据表的空间使用量
    SQL Server 2008维护计划 出错 无法实现自动备份
    SQL2008安装自动退出
    oracle自动备份
    吐槽一下金山卫士
  • 原文地址:https://www.cnblogs.com/xiaolovewei/p/8309029.html
Copyright © 2011-2022 走看看