iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >python排序算法(三)
  • 577
分享到

python排序算法(三)

算法python 2023-01-31 02:01:30 577人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

   OK,又到了苦逼的周一了。快排比较复杂,花了快两天琐碎时间琢磨了感觉还不是很好,据我们老师说当年提出快排的人是在上课突然想起来的,我等只能深深膜拜了    快速排序是一种具有良好平均性能的排序方法,插入排序将控制当前插入的基准记录插

   OK,又到了苦逼的周一了。快排比较复杂,花了快两天琐碎时间琢磨了感觉还不是很好,据我们老师说当年提出快排的人是在上课突然想起来的,我等只能深深膜拜了

   快速排序是一种具有良好平均性能的排序方法,插入排序将控制当前插入的基准记录插入相对于已经排好序的子表的正确位置,与此不同的是,快速排序将基准记录放在相对于整个列表的正确位置。这个听上去有点闹人,具体的解释我就不巴拉了,可以上网百度。

   以前写快排只实现最基本的功能,完全没考虑到一些边界问题,这些问题当我用python这门语言,当我想用随机数的列表来检验时,一下子暴露了,不过修补程序也是件很快乐的事啊!

   下面是修改后健壮性比较好的代码,基本不会报错或者陷入死循环:


,,

import random
def QuickSort(x,left,right):
    counter=0
    if(left<right):
        j=right
        pivot=x[left]
        i=left+1
        while(i<=j):
            while(x[i]<=pivot and i<right):
                i+=1
                counter+=1
            while(x[j]>pivot and j>left):
                j-=1
                counter+=1
            if(i<j):
                InterChange(x,i,j)
                counter+=1
            if(i==j):
                break
        InterChange(x,left,j)
        counter+=1
        if(j-left>1):
            counter+=QuickSort(x,left,j-1)
        if(right-j>1):
            counter+=QuickSort(x,j+1,right)
    return counter
def InterChange(x,i,j):
    temp=x[i]
    x[i]=x[j]
    x[j]=temp
x=[]
for a in range(1000):
    x.append(random.randint(1,1000))
#x=[27,85,69,99,97,49,22,64,7,24,10,13,73,99,95,12,89,83,54]
#for a in x:
    #print(a)
print('*********')
for a in x:
    if(a>x[len(x)-1]):
        InterChange(x,x.index(a),len(x)-1)
counter=QuickSort(x,0,len(x)-1)
for a in x:
    print(a)
print(counter)

   这个程序中我counter计算应该不是很准确,主要精力不是放在上面了。整个过程可以用修好一个bug冒出一个bug来形容。其实主要的问题还是由于大量随机数会产生相同的数导致的……

   34、35行我注释掉了,当时其实程序大部分时候已经能跑成功了,当排序的数的单位设置为百时,但是运行十次会出一次错。为了调这个bug,我只好把排序的数设置为20,然后运行了几十遍之后终于得到这行宝贵的数据,对于这个bug,读者可以把第9行和第12行and后面的判断去掉体会一下。

   第9行和第12行本应该对称,但是9行多了个=号是因为有个潜在的死循环问题,主要是由相同的数引起的,比如这样的排列10,10,10,其中left指向第一个10,i指向第二个,j指向第3个,这样会陷入死循环出不去。但加了=号也导致了下面的问题。

   第8行一开始是没有=号的,但是这个会导致一个排序不彻底的bug,这个的话可以以x=[1,3,9,7,12,23,4,16,20],也就是我之前一直用的例子体会下。至于第18行和第19行又额外加了个i==j的判断是防止它若x[i]=x[j]=x[right],x[i+1]会越界的错这个问题也是用大规模随机数找到的。

   至于38—40行在开始把列表中最大数放到末尾,也是出于避免一些边界问题的考虑。

   现在的程序已经很稳定了,可以经得住随机数的考验,运行下来counter分布在10000—15000之间,但是偶尔(几十次会有一次)也会很高,达到100000的水平,这是因为快排的最坏复杂度是o(n*n)的原因。明天可能还要研究研究快排优化的问题,下面把这个程序最基本的部分给出来方便读者自己修改,基本程序本身是有bug的,读者可以根据需要自行调整下:


def QuickSort(x,left,right):
    counter=0
    if(left<right):
        j=right
        pivot=x[left]
        i=left+1
        while(i<=j):
            while(x[i]<pivot):
                i+=1
            while(x[j]>pivot):
                j-=1
            if(i<j):
                InterChange(x,i,j)
        InterChange(x,left,j)
        QuickSort(x,left,j-1)
        QuickSort(x,j+1,right)
def InterChange(x,i,j):
    temp=x[i]
    x[i]=x[j]
    x[j]=temp
x=[1,3,9,7,12,23,4,16,20]
print('*********')
for a in x:
    if(a>x[len(x)-1]):
        InterChange(x,x.index(a),len(x)-1)
QuickSort(x,0,len(x)-1)
for a in x:
    print(a)

   这个基本程序的bug是不能有相同的数,否则会陷入死循环的哦~~

--结束END--

本文标题: python排序算法(三)

本文链接: https://www.lsjlt.com/news/185892.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • python排序算法(三)
       OK,又到了苦逼的周一了。快排比较复杂,花了快两天琐碎时间琢磨了感觉还不是很好,据我们老师说当年提出快排的人是在上课突然想起来的,我等只能深深膜拜了    快速排序是一种具有良好平均性能的排序方法,插入排序将控制当前插入的基准记录插...
    99+
    2023-01-31
    算法 python
  • Python排序算法之堆排序算法
    目录1. 树满二叉树的特性:什么是完全二叉树?完全二叉树的专业概念:2. 二叉堆2.1 二叉堆的抽象数据结构2.2 API 实现3. 堆排序4. 后记本文从树数据结构说到二叉堆数据结...
    99+
    2023-01-07
    python堆排序算法实现 堆排序算法以及python实现 python 堆排序算法
  • python排序算法之希尔排序
    目录一、前言二、算法描述第一步:第二步:第三步:第四步:第五步:三、代码实现一、前言 相关知识来自《python算法设计与分析》。初级排序算法是指几种较为基础且容易理解的排序算法。初...
    99+
    2023-05-17
    python排序算法 python希尔排序
  • python排序算法之选择排序
    一、前言 相关知识来自《python算法设计与分析》。初级排序算法是指几种较为基础且容易理解的排序算法。初级排序算法包括插入排序、选择排序和冒泡排序3种。虽然它们的效率相对于高级排序...
    99+
    2023-05-17
    python排序算法 python选择排序
  • Python排序算法之冒泡排序
    目录1. 前言2. 冒泡排序算法2.1 摆擂台法2.2 相邻两个数字相比较3. 选择排序算法4. 插入排序5. 快速排序6. 总结1. 前言 所谓排序,就是把一个数据群体按个体数据的...
    99+
    2023-01-07
    怎么用python写出冒泡排序 python中的冒泡排序算法 python冒泡排序简单方法
  • Python排序算法之 选择排序
      一、选择排序(Selection sort)  选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理是每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,所以称为:选择排序。  1、原...
    99+
    2023-06-02
  • python排序算法之归并排序
    目录一、前言二、算法描述三、代码实现总结一、前言 相关知识来自《python算法设计与分析》。初级排序算法是指几种较为基础且容易理解的排序算法。初级排序算法包括插入排序、选择排序和冒...
    99+
    2023-05-17
    python排序算法 python归并排序
  • python排序算法(一)
       接触python这么些日子下来,感触最深的就是有的知识是相通的,是无论编程语言的,比如说算法O(∩_∩)O~。So,今天开始用python再把之前学过的排序算法重写一遍,权当复习提升吧。    第一个是冒泡排序:def bubble...
    99+
    2023-01-31
    算法 python
  • 图解Java排序算法之快速排序的三数取中法
    目录基本步骤三数取中根据枢纽值进行分割代码实现总结基本步骤 三数取中 在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。在此我们采用三数取中法,也就是...
    99+
    2024-04-02
  • python冒泡法排序算法
    冒泡法排序思想:将数组中的数据两两进行比较,每次将较大的数据交换到后面,直到大数沉底,小数冒出。 可以这样想:10个数据有9组成对,每比完一组,则大的数沉到后面。渐渐地,要比较的数越少,小的数则冒到最前面。   例: 随机产生10个数,从...
    99+
    2023-01-30
    算法 python
  • 三路排序算法(Java 实例代码)
    目录   三路排序算法 一、概念及其介绍 二、适用说明 四、Java 实例代码 QuickSort3Ways.java 文件代码:   三路排序算法 一、概念及其介绍 三路快速排序是双路快速排序的进一步改进版本,三路排序算法把排序的数据分...
    99+
    2023-09-01
    排序算法 算法 java
  • Python实现排序算法1
    排序算法有很多种,下面列举几种:1.冒泡排序2.选择排序3.插入排序4.希尔排序5.快速排序6.归并排序1.冒泡排序 # -*- coding:utf-8 -*- def bubble_sort(alist): """冒泡排序"""...
    99+
    2023-01-31
    算法 Python
  • python 常用的排序算法
    1.插入排序:插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据,算法适用于少量数据的排序;首先将第一个作为已经排好序的,然后每次从后的取出插入到前面并排序; def insert_sor...
    99+
    2023-01-30
    算法 常用 python
  • python排序算法有哪些
    python中常见的排序算法有以下几种冒泡排序算法冒泡排序算法是一种简单直观的排序算法,其原理是重复地走访需要排序的元素列表,依次比较两个相邻的元素,如果顺序错误就交换它们的位置,重复地进行直到没有相邻的元素需要交换,则元素列表排序完成。选...
    99+
    2024-04-02
  • Java排序算法之怎么实现快速排序的三数取中法
    这篇文章主要讲解了“Java排序算法之怎么实现快速排序的三数取中法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java排序算法之怎么实现快速排序的三数取中法”吧!基本步骤三数取中在快排的过...
    99+
    2023-06-25
  • python排序算法之选择排序怎么实现
    一、前言初级排序算法是指几种较为基础且容易理解的排序算法。初级排序算法包括插入排序、选择排序和冒泡排序3种。虽然它们的效率相对于高级排序算法偏低,但是在了解初级排序算法之后,再去学习相对复杂的高级排序算法会容易许多。二、描述选择排序表示从无...
    99+
    2023-05-17
    Python
  • Python中有八大排序算法
    本篇文章为大家展示了Python中有八大排序算法,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、插入排序描述插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一...
    99+
    2023-06-17
  • java 排序算法之选择排序
    目录基本介绍基本思想思路分析代码实现演变过程优化算法函数封装大量数据耗时测试基本介绍 选择排序(select sorting)也属于内部排序法,是从欲排序的数据中,按指定的规则选出来...
    99+
    2024-04-02
  • Java排序算法之选择排序
    目录一、选择排序二、代码实现三、测试一、选择排序 选择排序就是在每一次遍历过程中将数组中值最小的排到当前的第一位。 总共需要(数组长度-1)次遍历,在每次遍历中假定第一位索引的值为最...
    99+
    2024-04-02
  • java排序算法之冒泡排序
    本文实例为大家分享了java排序算法之冒泡排序的具体代码,供大家参考,具体内容如下 冒泡排序 冒泡排序无疑是最为出名的排序算法之一,从序列的一端开始往另一端冒泡(你可以从左往右冒泡,...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作