• [leetcode]Sort List @ Python


    原题地址:http://oj.leetcode.com/problems/sort-list/

    题意:链表的排序。要求:时间复杂度O(nlogn),空间复杂度O(1)。

    解题思路:由于题目对时间复杂度和空间复杂度要求比较高,所以查看了各种解法,最好的解法就是归并排序,由于链表在归并操作时并不需要像数组的归并操作那样分配一个临时数组空间,所以这样就是常数空间复杂度了,当然这里不考虑递归所产生的系统调用的栈。

           这里涉及到一个链表常用的操作,即快慢指针的技巧。设置slow和fast指针,开始它们都指向表头,fast每次走两步,slow每次走一步,fast到链表尾部时,slow正好到中间,这样就将链表截为两段。

           运行时需要将中文注释删掉,leetcode oj平台里面不支持中文字符。

    代码:

    # Definition for singly-linked list.
    # class ListNode:
    #     def __init__(self, x):
    #         self.val = x
    #         self.next = None
    
    class Solution:
        # @param head, a ListNode
        # @return a ListNode
        def merge(self, head1, head2):
            if head1 == None: return head2
            if head2 == None: return head1
            dummy = ListNode(0)                             #归并时,新建一个链表头结点
            p = dummy
            while head1 and head2:
                if head1.val <= head2.val:
                    p.next = head1
                    head1 = head1.next
                    p = p.next
                else:
                    p.next = head2
                    head2 = head2.next
                    p = p.next
            if head1 == None:
                p.next = head2
            if head2 == None:
                p.next = head1
            return dummy.next
            
        def sortList(self, head):
            if head == None or head.next == None:
                return head
            slow = head; fast = head                        #快慢指针技巧的运用,用来截断链表。
            while fast.next and fast.next.next:
                slow = slow.next
                fast = fast.next.next
            head1 = head
            head2 = slow.next
            slow.next = None                                #head1和head2为截为两条链表的表头
            head1 = self.sortList(head1)
            head2 = self.sortList(head2)
            head = self.merge(head1, head2)
            return head
  • 相关阅读:
    Linux 进程退出后自动启动
    Python UDP broadcast PermissionError: [Errno 13] Permission denied
    C# 获取MAC地址
    C# 多线程
    C# UdpClient 设置超时时间
    C# 控件聚焦
    C# 添加图片资源
    C# Listview 第一列不能居中
    Ubuntu 14.04 AM335x TI-RTOS 编译
    为AM335x移植Linux内核主线代码
  • 原文地址:https://www.cnblogs.com/zuoyuan/p/3699508.html
Copyright © 2020-2023  润新知