热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

排序算法简述1

排序算法冒泡排序选择排序插入排序快速排序归并排序希尔排序冒泡排序(拿一个数去和其他数比)数组中的一个元素分别和数组中的其他元素比较,满足

排序算法

  • 冒泡排序
  • 选择排序
  • 插入排序
  • 快速排序
  • 归并排序
  • 希尔排序


冒泡排序

(拿一个数去和其他数比)数组中的一个元素分别和数组中的其他元素比较,满足一定要求时,便将两数的索引进行交换,不停的进行此操作。(此方法表示在原地进行)

def bubble_sort(li):for i in range(len(li)-1): #第i趟排序for j in range(len(li)-i-1):if li[j]>li[j+1]: #升序,若要降序排序将大于号改为小于号即可li[j],li[j+1]=li[j+1],li[j]
选择排序

不停遍历整个数组,将满足要求的元素取出放入一个新列表中

(此代码复杂度较高)
def select_sort_simple(li):li=[]for i in range(len(li)):min_val=min(li)li.append(min_val)li.remove(min_val)return li

插入排序

插入排序:(用其他数与一个数比)控制前方数字,将后面的数字陆续与前方的数字做比较,满足要求时便将数字插入即可(原地进行)

def insert_sort(li):for i in range(1,len(li)):tmp=li[i]j=i-1while li[j]>tmp and j>=0:li[j+1]=li[j]j-=1li[j+1]=tmp

快速排序

先将第一个元素取出,然后现在开始用右边的数与其比较,若有一个比其小的数,便将这个数移到取出的第一个元素的位置,这时,这个数的位置便又空了,接着就需要看左边比取出元素大的数,将其移到右边空的位置,然后再看右边比取出元素小的数移到左边的位置,周而复始的左右左右移动,即可完成程序

def partition(li,left,right): #left表示第一个元素的索引&#xff0c;即0&#xff1b;right表示最后一个元素的索引&#xff0c;即len(li)-1tmp&#61;li(left)while left<right:while li[right]>&#61;tmp and left<right:right-&#61;1li[left]&#61;li[right]while left<right and li[left]<&#61;tmp:left&#43;&#61;1li[right]&#61;li[left]li[left]&#61;tmp

归并排序

归并排序&#xff1a;即对序列的元素进行逐层折半分组&#xff0c;然后从最小分组开始比较排序&#xff0c;合并成一个大的分组&#xff0c;逐层进行&#xff0c;最终所有的元素都是有序的。归并一般使用情况是先分解&#xff0c;即将列表越分越小&#xff0c;直至分成一个元素&#xff1b;终止条件是当一个元素是有序的&#xff1b;最后是合并是将两个有序列表归并&#xff0c;列表越来越大.
在这里插入图片描述

def merge(li,low,mid,high):i&#61;lowj&#61;mid&#43;1tmp&#61;[]while i<&#61;mid and j<&#61;high:if li[i]<li[j]:tmp.append(li[i])i&#43;&#61;1else:tmp.append(li[j])j&#43;&#61;1while i<&#61;mid:tmp.append(li[i])i&#43;&#61;1while j<&#61;high:tmp.append(li[i])j&#43;&#61;1li[low:high&#43;1]&#61;tmp

希尔排序

是一种分组插入排序算法&#xff0c;首先取一个整数d1&#61;n//2&#xff0c;将元素分为d1个组&#xff0c;每组相邻量元素之间距离为d1&#xff0c;在各组内进行直接插入排序&#xff0c;同理之后取第二个整数d2&#61;d1//2&#xff0c;继续以上操作&#xff0c;直至dn&#61;1&#xff0c;就表明已将所有元素在同一组内进行直接插入排序。注&#xff1a;希尔排序每次遍历排序并没有使一些元素有序&#xff0c;是混乱的&#xff0c;但是整体是趋于有序的
在这里插入图片描述

def insert_sort_gap(li,gap):for i in range(gap,len(li)):tmp&#61;li[i]j&#61;i-gapwhile j>&#61;0 and li[j]>tmp:li[j&#43;gap]&#61;li[j]j-&#61;gapli[j&#43;gap]&#61;tmpprint(li)def shell_sort(li):d&#61;len(li)//2while d>&#61;1:insert_sort_gap(li,d)d//&#61;2


推荐阅读
  • C++实现经典排序算法
    本文详细介绍了七种经典的排序算法及其性能分析。每种算法的平均、最坏和最好情况的时间复杂度、辅助空间需求以及稳定性都被列出,帮助读者全面了解这些排序方法的特点。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • 深入理解C++中的KMP算法:高效字符串匹配的利器
    本文详细介绍C++中实现KMP算法的方法,探讨其在字符串匹配问题上的优势。通过对比暴力匹配(BF)算法,展示KMP算法如何利用前缀表优化匹配过程,显著提升效率。 ... [详细]
  • 在金融和会计领域,准确无误地填写票据和结算凭证至关重要。这些文件不仅是支付结算和现金收付的重要依据,还直接关系到交易的安全性和准确性。本文介绍了一种使用C语言实现小写金额转换为大写金额的方法,确保数据的标准化和规范化。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 本文介绍如何使用 NSTimer 实现倒计时功能,详细讲解了初始化方法、参数配置以及具体实现步骤。通过示例代码展示如何创建和管理定时器,确保在指定时间间隔内执行特定任务。 ... [详细]
  • 本文详细介绍了Java中org.w3c.dom.Text类的splitText()方法,通过多个代码示例展示了其实际应用。该方法用于将文本节点在指定位置拆分为两个节点,并保持在文档树中。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文介绍如何使用 Python 编写程序,检查给定列表中的元素是否形成交替峰值模式。我们将探讨两种不同的方法来实现这一目标,并提供详细的代码示例。 ... [详细]
author-avatar
一截藏青线
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有