`
darklipeng
  • 浏览: 126467 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

python实现快速排序法

阅读更多

以中轴分左右区的快速排序法:

# -*- coding: utf-8 -*-
class QuickSort:
    def sort(self,list,left,right):
        if(left<right):
            s=list[(left+right)/2]
            i=left
            j=right
            while(True):
                while(list[i]<s):
                    i+=1
                while(list[j]>s):
                    j-=1
                if(i>=j):
                    break
                self.swap(list,i,j)   
            self.sort(list,left,i-1)
            self.sort(list,j+1,right)
        else:
             return
            
    def swap(self,list,i,j):
        t=list[i]
        list[i]=list[j]
        list[j]=t

print 'begin:'
l=[32,32,34,43,66,65,67,31,77,54,100,42]
l=list(set(l))#防止队列中含有重复数
print l
q=QuickSort()
q.sort(l,0,len(l)-1)
print l

分享到:
评论

相关推荐

    Python实现快速排序.rar

    在这个Python实现的压缩包中,包含了一个名为"Python实现快速排序.py"的文件,我们可以深入探讨一下快速排序的原理以及如何用Python来实现它。 快速排序的步骤如下: 1. **选择枢轴元素(Pivot Selection)**:从...

    通过python实现快速排序代码示例.zip

    快速排序(Quicksort)是一种高效的排序算法,使用分治法(Divide and Conquer)策略来把一个序列分为较小和较大的两个子序列,然后递归地排序两个子序列。压缩包文档记录的是用Python实现快速排序的代码示例。

    快速排序算法Python实现:详解分治法原理与高效排序步骤

    内容概要:本文详细解析了快速排序算法的实现原理,重点介绍了分治...③掌握Python实现快速排序的具体步骤。 其他说明:本文不仅讲解了理论知识,还提供了实用的代码示例,便于读者通过实践深入理解算法的本质和优势。

    快速排序 --- 非递归实现

    在非递归实现快速排序时,通常会用到栈来保存每次划分的子数组范围。在这个案例中,`mt_stack.cpp`、`mt_stack.h`可能包含了自定义栈的实现,用于存储子数组的起始和结束索引。栈的数据结构使得我们可以按照后进先出...

    python实现快速排序的几种方法.docx

    ### Python 实现快速排序的几种方法 #### 快速排序算法概述 快速排序是一种非常高效的排序算法,由英国计算机科学家托尼·霍尔(Tony Hoare)于1960年提出。它采用分治法策略来把一个序列分为较小和较大的两个子...

    Python3实现快速排序(源代码)

    这段代码展示了如何使用Python3实现快速排序。需要注意的是,这种实现方式在处理大数据集时效率较低,因为它在每次分割时都会重新构建两个列表。在实际应用中,推荐使用**原地排序**的方法,通过交换数组中的元素来...

    基于python实现的快速排序算法.zip

    在Python中实现快速排序,我们可以将其分为以下几个关键步骤: 1. **选择基准元素(Pivot Selection)**:首先,我们需要从数组中选择一个元素作为基准,这个元素将用来划分数组。通常选取第一个或最后一个元素,也...

    快速排序算法的Python实现与解析

    内容概要:本文介绍了经典的快速排序算法及其Python实现。文中详细解释了快速排序的工作机制,即使用分治法的思想,选择基准点后将其划分为左中小三部分,并通过递归方式继续划分直至完成整个序列的排序。此外,还...

    快速排序算法详解及Python实现

    本文介绍了快速排序的基本原理,并提供了Python实现代码。代码中采用了基准选择为数组的第一个元素,并使用列表推导式实现分区操作。通过递归排序左右子数组,最终合并为一个有序数组。此外,针对最坏情况时间复杂度...

    通过python实现多种排序算法.rar

    压缩包文件代码是通过Python来实现多种排序算法。这里,将展示几种常见的...快速排序是一种高效的排序算法,采用分治法(Divide and Conquer)策略来把一个序列分为较小和较大的两个子序列,然后递归地排序两个子序列。

    Python实现归并排序.rar

    例如,如果你有一个包含大量数据的列表,需要快速排序且保持原有的相等元素顺序,那么归并排序就是一个很好的选择。 ### 总结 归并排序是计算机科学中一种经典且高效的排序算法,它的分治思想在许多其他问题中也...

    快速排序算法python实现.zip

    在Python中实现快速排序,我们可以定义一个函数,通常命名为`quick_sort`,这个函数接收一个列表作为参数。快速排序的核心在于选择一个基准元素(pivot)并进行分区操作。以下是快速排序算法的基本步骤: 1. **选择...

    Python快速排序以及其他排序方法集合

    快速排序是一种非常高效的排序算法,其核心思想是分治法。快速排序首先选取一个基准值,然后将数组分为两部分:一部分的所有元素都比基准值小;另一部分的所有元素都比基准值大。接下来对这两部分递归地执行同样的...

    高效排序算法:快速排序Java与Python实现详解

    内容概要:文章详述了快速排序算法的基本概念、分治策略以及具体实现方式,提供Java和Python两个版本的代码样例。快速排序算法能够将一个序列分解成较小和较大的两部分,并通过递归的方式分别对这两部分进行排序,...

    使用快速排序法对一维数组进行排序

    描述中的程序实现了快速排序法,可能是用一种编程语言如C++、Java或Python编写的,用于对一维数组进行排序。这种程序的实现一般包括上述的三个主要步骤,并可能包含优化措施,例如处理小数组时改用插入排序,或者...

    Python实现各种排序借鉴.pdf

    快速排序也是基于分治法,选取一个基准元素,将序列分为小于和大于基准的两部分,然后对这两部分分别进行排序。平均时间复杂度同样是O(nlogn),但最坏情况下为O(n^2)。快速排序通常使用递归,通过一次划分操作将...

    快速排序的算法思想及Python版快速排序的实现示例

    下面是使用Python语言实现的快速排序算法示例代码: ```python #!/usr/bin/env python #_*_coding:utf-8_*_ def rand(x): import random if x x = 5 if x &gt; 1000: print("big data") return [] l = range...

    Python快速排序算法详解及优化策略

    文章首先解释了快速排序的基本原理,即通过分治法选择基准元素并进行分区操作,递归排序子数组,实现O(n log n)的平均时间复杂度。接着讨论了优化策略,包括三数取中法和尾递归优化,以减少递归深度和提升排序效率。...

    Python实现经典排序算法.rar

    本资源"Python实现经典排序算法.rar"包含了一系列用Python编写的经典排序算法的源代码,这对于学习和理解排序算法的原理及其在Python中的实现极具价值。 首先,让我们来探讨一下排序算法的基本概念。排序算法是一种...

    基于python-java-C++实现快速排序.zip

    **Python实现快速排序** 在Python中,可以利用内置的`list`和`slice`功能来方便地操作数组。首先,选取一个基准元素,然后用`list.index()`找到它的正确位置,将数组分成两部分。接着,对左右两部分递归调用快速...

Global site tag (gtag.js) - Google Analytics