快速排序详解(C语言/python)

时间:2022-12-11 14:15:52

快速排序详解

介绍:

快速排序于C. A. R. Hoare在1960年提出,是针对冒泡排序的一种改进。它每一次将需要排序的部分划分为俩个独立的部分,其中一个部分的数比的数都小。然后再按照这个方法对这俩个独立的部分分别进行快速排序,整个排序递归进行,从而使得整个数据变成有序序列。下面以一个8元素的乱序数组为例按照快速排序的思想,将这个数组一步一步的进行排序,再分别以C语言和python编写快速排序源码。本文全篇介绍从小到大排序,反序换符号就好

快排思想:

1.该数组的初始状态如下,一个8元素的乱序数组。接下来我们按照快排的思想来进行操作。

快速排序详解(C语言/python)

2.选择第一个元素为基准,将比它小的元素放在一起,大的元素放一起,划分之后的数组将会变成下图一般。

快速排序详解(C语言/python)

3.开始递归,将划分之后的俩个独立部分进行划分,如果独立部分只有一个元素了,就可以结束递归了。比如第一次划分之后的大元素部分,将其再次进行划分之后的结果如下图,以第一个元素65为基准进行划分,划分之后的部分都只有一个元素,因此可以结束递归,那接下来再看一下小元素的划分。

快速排序详解(C语言/python)

4.小元素划分,将小元素部分再次进行划分,以第一个元素38为基准进行划分,划分之后的大元素部分只有一个元素48,结束递归。而小元素部分还有俩个元素,需要进一步递归。

快速排序详解(C语言/python)

5.现在第一次划分之后的大小元素部分都完成了一层的递归,我们看一下数组当前的状态。红色框为大元素部分,经过一次划分之后,已经完成了排序。

快速排序详解(C语言/python)

6.小元素二次递归,以38为基准进行划分之后,比38小的还有俩个元素,需要继续进行划分,以24为基准进行划分,这里比24小的不存在,比24大的只有1个元素31,划分之后可以结束递归,到此所有的递归都已经结束了。再看一下现在的状态。

快速排序详解(C语言/python)

7.结束,从上图可以看到,递归结束之后,快排就已经完成了,一个乱序的数组现在变成了一个从小到大的有序数组。

树型图:

快速排序详解(C语言/python)

具体实现:

还是以上面的乱序数组为例来介绍快速排序是如何来进行划分的,这里介绍一种挺好理解的实现方法。

1.初始状态

快速排序详解(C语言/python)

2.以49为基准,right从后向前寻找比49小的。(从小到大排序,大的在后面不用管),找到31比49小。left从前向后面找比49大的,找到65,将65与31交换位置。当前状态如下:

快速排序详解(C语言/python)

3.继续right从后向前寻找比49小的,找到24。当前状态如下:

快速排序详解(C语言/python)

4.left继续寻找比49大的,找到right与left重合还是找不到就可以结束寻找了。

快速排序详解(C语言/python)

5.这时候再将49与left所在的交换位置。

快速排序详解(C语言/python)

6.这就是完成了一次划分,之后按照这个方法,递归划分即可。

编码实现C语言:

 #include <stdio.h>
 #include <stdlib.h>
 //将arr数组中下标为i的与下标为j的交换位置
 void Swap(int arr[], int i, int j)
 {
     int temp;
     temp = arr[i];
     arr[i] = arr[j];
     arr[j] = temp;
 }
 //将arr数组进行划分
 int Partition(int arr[], int left, int right)
 {
     //保存起始下标
     int index = left;
     //获取基准的值
     int tmp = arr[left];
     //循环查找  当left与right重合之后结束
     while(left < right)
     {
         while(left < right && arr[right] >= tmp)
         {
             right --;
         }
         //right从后面开始找  找到比tmp小的
         while(left < right && arr[left] <= tmp)
         {
             left ++;
         }
         //left从前面开始找  找到比tmp大的
         Swap(arr, left, right);
         //将找出来的俩个交换位置
     }
     Swap(arr,index,left);
     //将基准值换到left的位置上面,完成划分
     return left;
 }

 void Qsort(int arr[], int left, int right)
 {
     int index;
     if(left < right)
     {
         //划分arr数组  下标left到right部分
         index = Partition(arr, left, right);
         //划分完成之后递归对俩个独立分区进行快排
         Qsort(arr, left, index - );
         Qsort(arr, index + , right);
     }
 }
 int main()
 {
     ]= {,,,,,,,};
     int  i;
     Qsort(arr, , );
     ; i<; ++i)
     {
         printf("%d ",arr[i]);
     }
     ;
 }

编码实现python:

 # coding=utf8
 import uuid
 import random
 import string

 def partition(alist, start, end):
     index = start
     tmp = alist[start]
     while start < end:
         while (start < end and alist[end] >= tmp):
             end -= 1
         while (start < end and alist[start] <= tmp):
             start += 1
         alist[start],alist[end] = alist[end],alist[start]
     alist[index], alist[end] = alist[end], alist[index]
     return end

 def quick_sort(alist, start, end):
     if start >= end:
         return
     left = partition(alist, start, end)
     # 对左边部分执行快速排序
     quick_sort(alist, start, left - 1)
     # 对右边部分执行快速排序
     quick_sort(alist, left + 1, end)

 qlist = [49,38,65,48,24,31,62,79]
 #qlist = [1, 12, 22, 34, 21, 4, 6, 8, 11, 54, 36, 7, 3, 0, 60, 62, 63]
 quick_sort(qlist, 0, len(qlist) - 1)
 print(qlist)

python一条语句解决快排源码:

quick_sort = lambda array: array if len(array) <= 1 else quick_sort([item for item in array[1:] if item <= array[0]]) +[array[0]] + quick_sort([item for item in array[1:] if item >array[0]])

快速排序详解(C语言/python)的更多相关文章

  1. 详解go语言的array和slice 【二】

    上一篇已经讲解过,array和slice的一些基本用法,使用array和slice时需要注意的地方,特别是slice需要注意的地方比较多.上一篇的最后讲解到创建新的slice时使用第三个索引来限制sl ...

  2. 详解 Go 语言中的 time&period;Duration 类型

    swardsman详解 Go 语言中的 time.Duration 类型swardsman · 2018-03-17 23:10:54 · 5448 次点击 · 预计阅读时间 5 分钟 · 31分钟之 ...

  3. 【机器学习】【条件随机场CRF-2】CRF的预测算法之维特比算法&lpar;viterbi alg&rpar; 详解 &plus; 示例讲解 &plus; Python实现

    1.CRF的预测算法条件随机场的预测算法是给定条件随机场P(Y|X)和输入序列(观测序列)x,求条件概率最大的输出序列(标记序列)y*,即对观测序列进行标注.条件随机场的预测算法是著名的维特比算法(V ...

  4. 详解Go语言调度循环源码实现

    转载请声明出处哦~,本篇文章发布于luozhiyun的博客: https://www.luozhiyun.com/archives/448 本文使用的go的源码15.7 概述 提到"调度&q ...

  5. Rserve详解&comma;R语言客户端RSclient【转】

    R语言服务器程序 Rserve详解 http://blog.fens.me/r-rserve-server/ Rserve的R语言客户端RSclient https://blog.csdn.net/u ...

  6. Python实现的数据结构与算法之快速排序详解

    一.概述 快速排序(quick sort)是一种分治排序算法.该算法首先 选取 一个划分元素(partition element,有时又称为pivot):接着重排列表将其 划分 为三个部分:left( ...

  7. Golang——详解Go语言代码规范

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是Golang专题的第二篇,我们来看看Go的语言规范. 在我们继续今天的内容之前,先来回答一个问题. 有同学在后台问我,为什么说Gola ...

  8. 详解C语言的类型转换

    1.自动类型转换 字符型变量的值实质上是一个8位的整数值,因此取值范围一般是-128-127,char型变量也可以加修饰符unsigned,则unsigned char 型变量的取值范围是0-255( ...

  9. 代码与图详解性能之Python集合类型&lpar;list tuple dict set generator&rpar;

    Python内嵌的集合类型有list.tuple.set.dict. 列表list:看似数组,但比数组强大,支持索引.切片.查找.增加等功能. 元组tuple:功能跟list差不多,但一旦生成,长度及 ...

随机推荐

  1. Java代码规范

    Java代码规范 本Java代码规范以SUN的标准Java代码规范为基础,为适应我们公司的实际需要,可能会做一些修改.本文档中没有说明的地方,请参看SUN Java标准代码规范.如果两边有冲突,以SU ...

  2. BZOJ 1015 题解

    1015: [JSOI2008]星球大战starwar Description 很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治者整个星系.某一天,凭着一个偶然的机遇,一支反抗军摧毁了帝 ...

  3. Android利用Looper在子线程中改变UI

    MainActivity如下: package cn.testlooper; import android.app.Activity; import android.os.Bundle; import ...

  4. 【VC编程技巧】文件☞2&period;3CArchive的用法

    CArchive 对象提供了一个类型安全缓冲机制CArchive 对象提供了一个类型安全缓冲机制.用于将可序列化对象写入CFile 对象或从中读取可序列化对象.通常,CFile 对象表示磁盘文件:但是 ...

  5. 安装logstash&comma;elasticsearch&comma;kibana三件套(转)

    logstash,elasticsearch,kibana三件套 elk是指logstash,elasticsearch,kibana三件套,这三件套可以组成日志分析和监控工具 注意: 关于安装文档, ...

  6. 【第六篇】Volley之https相关

    Volley之https信任所有证书实现: public class HttpsTrustManager implements X509TrustManager { private static Tr ...

  7. redis源码笔记(一) —— 从redis的启动到command的分发

    本作品采用知识共享署名 4.0 国际许可协议进行许可.转载联系作者并保留声明头部与原文链接https://luzeshu.com/blog/redis1 本博客同步在http://www.cnblog ...

  8. Ubuntu apt-get update 失败

    apt-get碰上了"fetch http://--失败", 自带源在国内连接性不好. 解决:改用"阿里云Ubuntu源": https://www.yuren ...

  9. 如何搜索 git 提交记录

    如何搜索 git 提交记录 git log -p --all -G '可通过正则搜索' --pretty=format:'%ci' # 可跨分支搜索 # -S '通过文本搜索' git branch ...

  10. SQLServer 取 字段名称 类型 字段描述 等

    https://www.cnblogs.com/w2011/archive/2013/01/04/2844143.html SELECT 字段名= convert(varchar(100), a.na ...