排列组合c和a怎么计算(快速排序的详细过程)

上一章节已经详细的向大家介绍过排序的相关概念学习笔记-排序简单介绍,本文旨在为大家详细的介绍快速排序。

快速排序

快速排序(Quicksort)是对冒泡排序(学习笔记-详解冒泡排序)的一种改进,也是一种交换类排序。

快速排序由C. A. R. Hoare在1960年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以进行,以此达到整个数据变成有序。

学习笔记-详解快速排序

算法原理

本质是分而治之思想的运用。首先选取一个元素作为分界值,将大于该分界值的元素放在数组的右边,小于主元的元素放在数组的左边,等于分界值的元素位置不变,然后不断迭代上述规则完成排序。

快速排序算法的原理如下:

1,首先设定一个分界值,通过该分界值将数组分成左右两部分。

2,将大于或等于分界值的数据集中到数组右边,小于分界值的数据集中到数组的左边。此时,左边部分中各元素都小于或等于分界值,而右边部分中各元素都大于或等于分界值。

3,然后,左边和右边的数据可以独立排序。对于左侧的数组数据,又可以取一个分界值,将该部分数据分成左右两部分,同样在左边放置较小值,右边放置较大值。右侧的数组数据也可以做类似处理。

4,重复上述过程,可以看出,这是一个递归定义。通过递归将左侧部分排好序后,再递归排好右侧部分的顺序。当左、右两个部分各数据排序完成后,整个数组的排序也就完成了。

学习笔记-详解快速排序

算法实现#include <stdio.h> #define elemType int /*元素类型*/int k=1;//轮次记录 void Print (elemType *arr, int len){ int i; for (i=0; i<len; i++){ printf (“%d\t”, arr[i]); } printf(“\n”);}void Sort(elemType *a, int left, int right){ if(left >= right) /*如果左边索引大于或者等于右边的索引就代表已经整理完成一个组了*/ { return ; } int i = left; int j = right; int key = a[left]; printf(“第%d轮选取的key值为:%d\n”,k,key); while(i < j) /*控制在当组内寻找一遍*/ { while(i < j && key <= a[j]) /*而寻找结束的条件就是,1,找到一个小于或者大于key的数(大于或小于取决于你想升 序还是降序)2,没有符合条件1的,并且i与j的大小没有反转*/ { j–;/*向前寻找*/ } a[i] = a[j]; /*找到一个这样的数后就把它赋给前面的被拿走的i的值(如果第一次循环且key是 a[left],那么就是给key)*/ while(i < j && key >= a[i]) /*这是i在当组内向前寻找,同上,不过注意与key的大小关系停止循环和上面相反, 因为排序思想是把数往两边扔,所以左右两边的数大小与key的关系相反*/ { i++; } a[j] = a[i]; } a[i] = key; /*当在当组内找完一遍以后就把中间数key回归*/ printf(“第%d轮排序后结果如下:\n”,k); Print(a, 9); k=k+1; Sort(a, left, i – 1); /*最后用同样的方式对分出来的左边的小组进行同上的做法*/ Sort(a, i + 1, right); /*用同样的方式对分出来的右边的小组进行同上的做法*/ /*当然最后可能会出现很多分左右,直到每一组的i = j 为止*/} int main() { int i; elemType arr[9] = {94,19,29,9,11,1,14,13,29}; printf(“待排序的序列为:\n”); Print(arr, 9); printf(“\n\n”); Sort (&arr,0,8); printf(“\n\n”); printf(“排好序的结果如下:\n”); Print(arr, 9); }
学习笔记-详解快速排序

序列红框为界

算法分析
学习笔记-详解快速排序

时间复杂度

快速排序的一次划分算法从两头交替搜索,直到left和right重合,因此其时间复杂度是O(n);而整个快速排序算法的时间复杂度与划分的趟数有关。

最优情况:每次划分所选择的中间数恰好将当前序列几乎等分,经过log2n趟划分,便可得到长度为1的子表。这样,整个算法的时间复杂度为O(nlog2n)。

最坏情况:每次所选的中间数是当前序列中的最大或最小元素,这使得每次划分所得的子表中一个为空表,另一子表的长度为原表的长度-1。这样,长度为n的数据表的快速排序需要经过n趟划分,使得整个排序算法的时间复杂度为O(n2)。

为改善最坏情况下的时间性能,可采用其他方法选取中间数。通常采用“三者值取中”方法,即比较H->r[left].key、H->r[right].key与H->r[(left + right)/2].key,取三者中关键字为中值的元素为中间数。

可以证明,快速排序的平均时间复杂度也是O(nlog2n)。因此,该排序方法被认为是目前最好的一种内部排序方法。

空间复杂度

从空间性能上看,尽管快速排序只需要一个元素的辅助空间,但快速排序需要一个栈空间来实现递归。最好的情况下,即快速排序的每一趟排序都将元素序列均匀地分割成长度相近的两个子表,所需栈的最大深度为log2(n+1);但最坏的情况下,栈的最大深度为n。这样,快速排序的空间复杂度为O(log2n))。适合在数据集比较大的时候使用。

算法稳定性

值得注意的是,快速排序是一种不稳定的排序算法,也就是说,多个相同的值的相对位置也许会在算法结束时产生变动。

 

本文来自投稿,不代表展天博客立场,如若转载,请注明出处:https://www.me900.com/267451.html

(0)

相关推荐

  • 中餐宴会菜单 本次宴会菜单有什么

    #头条创作挑战赛# 炝锅鲜鲍鱼 原料: 鲜鲍4只笋片100克青红小米椒碎30克芹菜碎20克姜米、蒜米、葱花、盐、酱油、白糖、味精、红油、鸡油各适量制作:1.把笋片投沸水锅里飞水后,放盘里垫底;另取鲍鱼片成片,然后投入加有盐和料酒的沸水锅里汆断生,捞出来盛盘内笋片上边。2.取姜米、蒜米、葱花、盐、酱油、白糖、味精和红油纳碗,调成红油味汁后浇在盘中鲍片上。另锅上…

    2023-06-06
  • 流量卡套餐39(流量卡套餐怎么取消)

    ??怎么选择一款性价比较高的套餐呢,小编认为:1是要资费便宜,2是当然能长期使用。 ??今天,小编给大家推荐的这几款流量卡正好可以满足这两条需求,不仅资费便宜,而且不像其他的流量卡只有1年/2年的优惠期,这几款流量卡可以长期使用不换号,超级省心。 ? ??首先在推荐之前,要给大家解决几个很多朋友都一直在关注的热点问题。 ??1、长期套餐是什么?简单来说长期有…

    2023-05-25 知识百科
  • 网络货币兑换(斯里兰卡卢比兑换人民币)

    中国银行马尼拉分行近期推出了针对其个人客户的“比索-人民币在线兑换”功能。 中国银行马尼拉分行供图 中新网马尼拉12月13日电 中国银行马尼拉分行近期推出了针对其个人客户的“比索-人民币在线兑换”功能:通过手机银行和个人网上银行,用户可以实时方便地将比索兑换成为人民币、美元、欧元等货币。 近来,中国银行大力推进多项数字银行服务。马尼拉中行邓军行长表示,在线兑…

    2022-01-27
  • 2020年LOL新年抽奖大赛 全民期待

    英雄联盟2020lol幸运召唤师4月官方网址及最新幸运召唤师抽奖入口!玩家朋友们期待已久的幸运召唤师活动又来啦,怎么样才能获得辛运召唤师资格呢?如何才能抽取低折扣呢?抽奖地址在哪呢? 活动时间:2020.04.17-2020.04.30 活动地址:点击进入>>> 暂无4月活动的具体消息,敬请期待! 幸运召唤师: 每一种折扣道具仅限购买一个 活动地址:http…

    2023-06-08
  • 流量卡一般多少钱一张(流量卡多少钱一张买了)

    相信很多小伙伴经常可以在某手某音刷到9.9包100g流量卡,19.9包100g流量卡这种其实都是物联卡 入 正 题 什么是物联卡? 物联网卡是由三大运营商 (移动、联通、电信)提供,基于物联网专网,用来满足智能硬件的联网、管理,以及集团公司的移动信息化应用需求的流量卡。 网上叫卖的物联卡,也通常被叫作纯流量卡,宣称0月租,套餐资费比较便宜,与普通卡的最大区别…

    2023-05-31
  • 学信网学历认证查询,学历认证查询:最新学信网认证技巧

    国内学位认证报告的验证 自2022年8月15日起,国内学位信息查询与认证服务网站由“学位网”调整到“学信网”(www.chsi.com.cn)。调整后,学位网网页及小程序的学位认证报告查询和验证功能将停止使用,学位报告的查验可通过学信网网页、小程序、APP等方式进行。相关操作整理如下: 《中国高等教育学位在线验证报告》 (样张) 一 学信网网页验证 点击学信…

    2023-05-22
  • 百度小说排行,《百度小说排行榜:最受欢迎的小说》

    盘点十本已完结的网文巅峰之作,我想你应该都看过! 第十本:耳根《求魔》 图片来源于网络,如有侵权请联系删除 这是番茄所有作品中,我最喜欢的一本,虽然星辰变和吞噬星空口碑炸裂,但给我的感觉这二者几乎算是纯粹的升级文,但盘龙的故事更加紧凑,林雷的性格和他的冒险故事更让我喜欢,创下十几项记录不说,更是被外国读者用来戒毒,这操作也是没谁了。 第六本爱潜水的乌贼《诡秘…

    2023-05-19
  • 怎么清理手机储存空间最快(华为手机内存卡怎么清理)

    玩机技巧如何清理手机存储空间缓存呢? 这个问题应该是很多朋友困惑的问题,当我们平时刷手机看视频的时候,浏览网页的时候,手机上面会产生很多的垃圾文件,刚刚开始不会觉得卡顿,用一段时间之后,会觉的手机特别的卡,那我们如何进行清理手机缓存呢,具体大家往下看。 玩机技巧如何清理手机存储空间缓存 打开手机上的设置按钮,不同的手机位置可能不相同,大家好好找一下,具体看图…

    2023-05-29 知识百科
  • 唐云的料理攻略,唐云的烹饪技巧:烹饪美味佳肴的简单方法

    本故事已由作者:猪蹄小黄花,授权每天读点故事app独家发布,旗下关联账号“每天读点故事”获得合法转授权发布,侵权必究。 1 我在胡同里喝了半天的西北风,雷珠珠打电话说,帅哥临时有约,没空拿下个季度新品样板过来给我。 “雷珠珠,色字头上一把刀,你等着我去打爆你的狗头。”我对着手机大吼。 就在我骑着小电驴准备回家的时候,一个身形微胖的女人带了六七个女人冲进巷子,…

    2023-05-13
  • 客户粘性与黏性的区别(客户粘性是指)

    以前,新客户的获得成本很低,大多数商家并不在意客户关系管理,但当流量红利消失,进入如今的存量竞争时代,商家们才意识到,原来电商CRM真的很重要,也纷纷开始布局做电商CRM。 电商CRM,即客户关系管理,是指通过一系列工具和方法,围绕获客、激活、留存、变现、传播、裂变等环节管理客户,强化与客户之间的关系,提高客户生命周期的价值。 当下,电商CRM火热至极,那它…

    2023-02-14
  • 家里不得养的十大凶龟,养乌龟有哪些风水禁忌

    乌龟作为一种长命百岁的动物,寓意吉祥,现在越来越受到大家的喜爱,越来越多的人选择在家中养乌龟,这样才能够得到更好的风水作用,而且风水乌龟还有招财纳气的良好作用,但是其实再养乌龟的时候也要注意一些风水禁忌才能够得到最大程度的招财作用,尤其是一些人并不适合养乌龟,在家中有了乌龟之后,反而会破财,今天我们就来看看养乌龟到底有哪些风水禁忌。 一、养乌龟的作用 乌龟作…

    2023-02-12
  • 淘宝对卖家发布的商品数量是否有限制(淘宝各类名词解释)

    伙伴们可以持自己的身份证在淘宝开个人店铺,开个人店铺流程也不复杂,大家按要求操作就行,但是开店得了解开店的规则,所以我现在给大家讲一讲淘宝个人开店的一些规则。 1、关于淘宝店铺注册部分:其实最重要的是要注意注册过程中是否存在一些违规行为,可能导致后续账户被回收。比如六个月内不登录淘宝,就已经满足了非活跃淘宝用户的要求,淘宝有权收回账号。 2、关于经营部分:在…

    2021-12-06 知识百科