当前位置:主页 > python教程 > Python实现插入排序和选择排序的方法

Python实现插入排序和选择排序的实例内容详解

发布:2019-08-29 14:04:58 194


为网友们分享了相关的编程文章,网友曹静竹根据主题投稿了本篇教程内容,涉及到python、插入排序、python选择排序、Python实现插入排序和选择排序的方法相关内容,已被542网友关注,涉猎到的知识点内容可以在下方电子书获得。

Python实现插入排序和选择排序的方法

话不多说,让我们从最基本的排序算法开始吧

插入排序

如下图所示,插入排序的实现思路顾名思义,就是 不断地在一个已经是有序的数组中,寻找合适位置并插入新元素 。

Python实现插入排序和选择排序的方法

具体实现步骤为:

首先我们把整个数组拆分为有序区间和未排序区间,有序区间在插入排序一开始只有一个元素,就是数组的第一个元素。

接在有序区间之后的一个元素就是准备插入的元素,在图中就是标为绿色的元素,在有序区间内寻找位置并插入。

其寻找逻辑为:从后往前依次进行比较,如果待插入元素大于当前元素,则将待插入元素插入到当前元素的后一位,如果待插入元素小于当前元素,则将当前元素后移一位。不断重复该过程直至到数组的最后一位

其实现的具体代码为:

def insertion_sort(a):
 length = len(a)
 if length <=1:
  return 
 for i in range(1,length):
  j = i-1
  value = a[i]
  while j >=0:
   if a[j]<value:
    a[j+1] = value
    break
   else:
    a[j+1] = a[j]
    if j == 0:
     a[j] = value 
   j -=1
  print(a)

    return a时间复杂计算为:我们需要将整个数组遍历一遍,所以这一部分为O(n),在每一次遍历中都要执行一次插入操作,其时间复杂度为O(n),所以总时间复杂度为O(n2)

选择排序

选择排序跟插入排序算法类似,都是将数组分为有序区间和未排序区间,区别在于插入排序是将一个新元素插入到有序区间内,而选择排序则是在未排序区间中找到最小元素,并交换到有序区间之后。

Python实现插入排序和选择排序的方法

实现代码为:

def selection_sort(a):
 length = len(a)
 if length <=1:
  return
 for i in range(0,length-1):
  min_value = a[i]
  min_index = i
  j = i+1
  while j<length:
   if a[j] < min_value:
    min_value = a[j]
    min_index = j
   j += 1
  a[i],a[min_index] = a[min_index],a[i]

    return a时间复杂度计算:数组长度为n,一共需要寻找n次最小值,每次寻找最小值都要遍历未排序区间一次,其时间复杂度为O(n),乘以n次为O(n2)


参考资料

相关文章

  • python定时复制远程文件代码实现

    发布:2020-06-22

    这篇文章主要为大家详细介绍了python定时复制远程文件夹中所有文件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下


  • python列表元素拼接成字符串的4种方法

    发布:2023-03-27

    本文主要介绍了python列表元素拼接成字符串的4种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧


  • Python 实现还原已撤回的微信消息

    Python 实现还原已撤回的微信消息

    发布:2023-01-04

    为网友们分享了关于Python的教程,这篇文章主要介绍了Python 神操作,还原已撤回的微信消息功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下


  • Python编程实现双击更新所有已安装python模块的方法

    发布:2022-06-22

    给大家整理了关于Python的教程,这篇文章主要介绍了Python编程实现双击更新所有已安装python模块的方法,涉及Python针对模块操作命令的相关封装与调用技巧,需要的朋友可以参考下


  • python解包裹传递是什么

    发布:2021-06-15

    python解包裹传递的介绍:1、调用函数时,函数接收的实际参数为元组或字典类型时,可以使用“*”和“**”来解除函数参数的包裹。2、将实际参数分为多个值,并根据位置传递方式或关键词传递方式将值传递给各值。


  • 学python用什么教程

    学python用什么教程

    发布:2022-12-07

    给网友们整理关于python 教程的教程,适合python初学者的教程有《python编程从入门到实战》,《Python 基础教程》,《python学习手册》等,可以根据自己的编程基础来选择适合自己的教程。


  • python reverse反转部分数组详解

    发布:2020-02-14

    今天小编就为大家分享一篇python reverse反转部分数组的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧


  • python安装后无法打开IDLE Subprocess Connection Error的解决方法

    发布:2023-03-06

    有朋友在安装了Python之后发现不能正常使用,就说明安装过程出了问题,下面这篇文章主要给大家介绍了关于python安装后无法打开IDLE Subprocess Connection Error的解决方法,需要的朋友可以参考下


网友讨论