当前位置:首页 > 科技  > 软件

玩转Python插入排序:从基础到进阶,成为排序专家

来源: 责编: 时间:2023-09-20 21:55:16 408观看
导读插入排序是一种简单但有效的排序算法。它的基本思想是将待排序的元素逐个插入已排序序列中的正确位置,直到所有元素都被插入完成。插入排序的算法复杂度为O(n^2),适用于小规模的数据排序。本文将介绍插入排序的原理、具

插入排序是一种简单但有效的排序算法。它的基本思想是将待排序的元素逐个插入已排序序列中的正确位置,直到所有元素都被插入完成。插入排序的算法复杂度为O(n^2),适用于小规模的数据排序。本文将介绍插入排序的原理、具体实现和优化,并提供相关的Python代码示例。4hu28资讯网——每日最新资讯28at.com

4hu28资讯网——每日最新资讯28at.com

一、插入排序的基本原理

插入排序的基本原理可以用以下步骤描述:4hu28资讯网——每日最新资讯28at.com

  1. 将待排序序列的第一个元素看作已排序序列。
  2. 从第二个元素开始,逐个将元素插入已排序序列的正确位置。
  3. 每次插入时,从后往前比较已排序序列中的元素,将比当前元素大的元素依次向后移动,直到找到合适的插入位置。
  4. 重复步骤3,直到所有元素都被插入完成,得到有序序列。

插入排序的关键在于找到插入位置并进行元素的后移操作。这种排序算法类似于我们打扑克牌时整理手中的牌,每次将一张新牌插入到已排序的牌中的正确位置。4hu28资讯网——每日最新资讯28at.com

二、插入排序的具体实现

下面是插入排序的具体实现代码:4hu28资讯网——每日最新资讯28at.com

def insertion_sort(arr):    for i in range(1, len(arr)):        key = arr[i]  # 当前待插入元素        j = i - 1  # 已排序序列的最后一个元素的索引        while j >= 0 and arr[j] > key:            arr[j + 1] = arr[j]  # 比当前元素大的元素向后移动            j -= 1        arr[j + 1] = key  # 将当前元素插入到正确位置    return arr

三、插入排序的优化

插入排序是一种简单但是效率较低的排序算法,特别是对于大规模数据的排序。但是,我们可以通过一些优化策略来提高插入排序的性能。4hu28资讯网——每日最新资讯28at.com

优化1:减少元素的比较次数

在内层循环中,我们可以通过使用“哨兵”来避免每次比较都需要检查边界条件。我们可以将待插入的元素复制到一个临时变量中,并将其作为哨兵,然后在内层循环中只比较哨兵与已排序元素,而不是每次都访问原始数组。4hu28资讯网——每日最新资讯28at.com

def insertion_sort(arr):    for i in range(1, len(arr)):        key = arr[i]  # 当前待插入元素        j = i - 1  # 已排序序列的最后一个元素的索引        while arr[j] > key:            arr[j + 1] = arr[j]  # 比当前元素大的元素向后移动            j -= 1        arr[j + 1] = key  # 将当前元素插入到正确位置    return arr

优化2:使用二分查找确定插入位置

传统的插入排序是通过逐个比较已排序元素找到正确的插入位置。但是,我们可以使用二分查找来确定插入位置,从而减少比较的次数。4hu28资讯网——每日最新资讯28at.com

def insertion_sort(arr):    for i in range(1, len(arr)):        key = arr[i]  # 当前待插入元素        left, right = 0, i - 1  # 已排序序列的左右边界        while left <= right:            mid = (left + right) // 2  # 中间位置            if arr[mid] > key:                right = mid - 1            else:                left = mid + 1        for j in range(i - 1, left - 1, -1):            arr[j + 1] = arr[j]  # 比当前元素大的元素向后移动        arr[left] = key  # 将当前元素插入到正确位置    return arr

四、总结

本文介绍了插入排序的原理、具体实现和优化。插入排序是一种简单但有效的排序算法,适用于小规模的数据排序。通过不断将元素插入已排序序列的正确位置,最终得到有序序列。我们还介绍了两种优化策略,包括减少元素的比较次数和使用二分查找确定插入位置。这些优化可以提高插入排序的性能。通过掌握插入排序的原理和优化方法,我们可以更好地理解和应用这一常用的排序算法。4hu28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-10586-0.html玩转Python插入排序:从基础到进阶,成为排序专家

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 深入理解Java内存工作原理

下一篇: 极速Python编程:利用缓存加速你的应用程序

标签:
  • 热门焦点
  • 5月iOS设备性能榜:M1 M2依旧是榜单前五

    和上个月一样,没有新品发布的iOS设备性能榜的上榜设备并没有什么更替,仅仅只有跑分变化而产生的排名变动,刚刚开始的苹果WWDC2023,推出的产品也依旧是新款Mac Pro、新款Mac Stu
  • 女孩租房开2小时空调用完100元电费引热议:5级能耗惹不起 月薪过万电费也交不起

    近日,江苏苏州一女孩租房当天充值了100元电费,开着空调不到2小时发现电费已用完。对于为什么这个快,房东表示,电表坏了这种情况很多,之前也遇到过,给租客换
  • 十个简单但很有用的Python装饰器

    装饰器(Decorators)是Python中一种强大而灵活的功能,用于修改或增强函数或类的行为。装饰器本质上是一个函数,它接受另一个函数或类作为参数,并返回一个新的函数或类。它们通常用
  • 自律,给不了Keep自由!

    来源 | 互联网品牌官作者 | 李大为编排 | 又耳 审核 | 谷晓辉自律能不能给用户自由暂时不好说,但大概率不能给Keep自由。近日,全球最大的在线健身平台Keep正式登陆港交所,努力
  • ESG的面子与里子

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之三伏大幕拉起,各地高温预警不绝,但处于厄尔尼诺大&ldquo;烤&rdquo;之下的除了众生,还有各大企业发布的ESG报告。ESG是&ldquo;环境保
  • 年轻人的“职场羞耻感”,无处不在

    作者:冯晓亭 陶 淘 李 欣 张 琳 马舒叶来源:燃次元&ldquo;人在职场,应该选择什么样的着装?&rdquo;近日,在网络上,一个与着装相关的帖子引发关注,在该帖子里,一位在高级写字楼亚洲金
  • 国行版三星Galaxy Z Fold5/Z Flip5发布 售价7499元起

    2023年8月3日,三星电子举行Galaxy新品中国发布会,正式在国内推出了新一代折叠屏智能手机三星Galaxy Z Fold5与Galaxy Z Flip5,以及三星Galaxy Tab S9
  • 2022爆款:ROG魔霸6 冰川散热系统持续护航

    喜逢开学季,各大商家开始推出自己的新产品,进行打折促销活动。对于忠实的端游爱好者来说,能够拥有一款梦寐以求的笔记本电脑是一件十分开心的事。但是现在的
  • 电博会与软博会实现"线下+云端"的双线融合

    在本次“电博会”与“软博会”双展会利好条件的加持下,既可以发挥展会拉动人流、信息流、资金流实现快速交互流动的作用,继而推动区域经济良性发展;又可以聚
Top