当前位置: 首页 > news >正文

商丘做网站汉狮网络最有效的线上推广方式

商丘做网站汉狮网络,最有效的线上推广方式,网站优化怎么做论坛,企业网站备案需要哪些资料一、快速排序 1、快速排序总结 快速排序是一种高效的排序算法,基于分治法的思想。 分区操作是快速排序的核心,将数组分为两部分。 原地分区可以减少空间复杂度,提高效率。 快速排序的平均时间复杂度为 O(n log n),但在最坏情况…

一、快速排序

1、快速排序总结

  • 快速排序是一种高效的排序算法,基于分治法的思想。

  • 分区操作是快速排序的核心,将数组分为两部分。

  • 原地分区可以减少空间复杂度,提高效率。

  • 快速排序的平均时间复杂度为 O(n log n),但在最坏情况下(如输入数组已经排序)会退化到 O(n²)

2、快速排序的基本思路

  • 选择基准值(Pivot)

    • 从数组中选择一个元素作为基准值。基准值的选择可以是数组的第一个元素、最后一个元素、中间元素,或者随机选择。

  • 分区操作(Partition)

    • 将数组分为两部分:

      • 一部分包含小于基准值的元素。

      • 另一部分包含大于基准值的元素。

    • 基准值最终会放在它最终的位置上。

  • 递归排序

    • 对小于基准值的部分递归调用快速排序。

    • 对大于基准值的部分递归调用快速排序。

  • 合并结果

    • 由于分区操作已经将数组分为两部分,递归排序后,数组自然有序,无需额外的合并操作。

3、快速排序和冒泡排序的区别

  • 冒泡排序

    • 优点:实现简单,代码量少。

    • 缺点:效率低,时间复杂度为 O(n²),不适用于大规模数据。

  • 快速排序

    • 优点:效率高,平均时间复杂度为 O(n log n),适合大规模数据。

    • 缺点:实现相对复杂,不稳定排序算法。

二、代码

def quick_sort(arr):# 如果数组长度小于等于1,直接返回if len(arr) <= 1:return arr# 选择基准值(这里选择最后一个元素)pivot = arr[-1]# 分区操作left = [x for x in arr[:-1] if x <= pivot]  # 小于等于基准值的元素right = [x for x in arr[:-1] if x > pivot]  # 大于基准值的元素# 递归排序左右两部分,并拼接结果return quick_sort(left) + [pivot] + quick_sort(right)# 示例
nums = [3, 2, 1, 5, 6, 4]
sorted_nums = quick_sort(nums)
print(sorted_nums)  # 输出:[1, 2, 3, 4, 5, 6]
http://www.ds6.com.cn/news/12949.html

相关文章:

  • 贵阳公司网站广告策划方案范文
  • dw个人网站设计模板自媒体服务平台
  • 想找一个网站做安全测试新东方雅思培训机构官网
  • 无锡网站制作哪里实惠杭州网站优化体验
  • 外贸推广用中文网站建站工具
  • 惠州seo排名优化进行seo网站建设
  • wap网站做视频直播锦绣大地seo
  • 陕西外贸英文网站建设网络营销概述ppt
  • 中国疫情最新消息发布常熟seo关键词优化公司
  • 贵阳商城网站建设广告软文范例
  • 宝安做网站怎么样电脑清理优化大师
  • 要找人做公司网站应该怎么做网站接广告平台
  • 国内校园网站建设百度快照功能
  • 做外贸自己做网站么百度网盘搜索引擎入口在哪
  • 做公司网站需要提供的资料软文编辑器
  • 苏州seo培训多少钱廊坊seo管理
  • 做推送的网站除了秀米还有百度不能搜的十大禁词
  • 织梦做的网站怎么加弹窗山东服务好的seo公司
  • 做外贸要开通哪个网站如何做平台推广赚钱
  • 临沂建设网站百度客服在线客服入口
  • 党政门户网站怎么做软文写作范文500字
  • 网站建设开发协议自动收录
  • 上海网站制作网络推广厦门seo小谢
  • 公司网站建设需要什么网络营销公司注册找哪家
  • 花都手机网站建设镇江网站建设企业
  • 科技网站欣赏谷歌浏览器下载
  • 怎么做淘宝客的跳转网站seo外包是什么
  • seo 网站文章一般要多少字百度应用搜索
  • 自己做彩票网站犯法吗抖音推广网站
  • 漳州做网站制作免费的网络营销方式