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

开发笔记:快速排序详解(C语言/python)

快速排序详解介绍:      快速排序于C.

快速排序详解

介绍:

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

 

快排思想:

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

 技术图片

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

 技术图片

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

 技术图片

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

 技术图片

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

 技术图片

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

 技术图片

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

树型图:

 技术图片

 

 

具体实现:

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

 

1.初始状态

 技术图片

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

 技术图片

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

技术图片

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

技术图片

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

 技术图片

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

 

 

编码实现C语言:

技术图片技术图片

1 #include
2 #include
3 //将arr数组中下标为i的与下标为j的交换位置
4 void Swap(int arr[], int i, int j)
5 {
6 int temp;
7 temp = arr[i];
8 arr[i] = arr[j];
9 arr[j] = temp;
10 }
11 //将arr数组进行划分
12 int Partition(int arr[], int left, int right)
13 {
14 //保存起始下标
15 int index = left;
16 //获取基准的值
17 int tmp = arr[left];
18 //循环查找 当left与right重合之后结束
19 while(left < right)
20 {
21 while(left = tmp)
22 {
23 right --;
24 }
25 //right从后面开始找 找到比tmp小的
26 while(left tmp)
27 {
28 left ++;
29 }
30 //left从前面开始找 找到比tmp大的
31 Swap(arr, left, right);
32 //将找出来的俩个交换位置
33 }
34 Swap(arr,index,left);
35 //将基准值换到left的位置上面,完成划分
36 return left;
37 }
38
39 void Qsort(int arr[], int left, int right)
40 {
41 int index;
42 if(left < right)
43 {
44 //划分arr数组 下标left到right部分
45 index = Partition(arr, left, right);
46 //划分完成之后递归对俩个独立分区进行快排
47 Qsort(arr, left, index - 1);
48 Qsort(arr, index + 1, right);
49 }
50 }
51 int main()
52 {
53 int arr[10]= {49,38,65,48,24,31,62,79};
54 int i;
55 Qsort(arr, 0, 7);
56 for(i=0; i<8; ++i)
57 {
58 printf("%d ",arr[i]);
59 }
60 return 0;
61 }


View Code

编码实现python:

技术图片技术图片

1 # coding=utf8
2 import uuid
3 import random
4 import string
5
6 def partition(alist, start, end):
7 index = start
8 tmp = alist[start]
9 while start < end:
10 while (start and alist[end] >= tmp):
11 end -= 1
12 while (start and alist[start] <= tmp):
13 start += 1
14 alist[start],alist[end] = alist[end],alist[start]
15 alist[index], alist[end] = alist[end], alist[index]
16 return end
17
18 def quick_sort(alist, start, end):
19 if start >= end:
20 return
21 left = partition(alist, start, end)
22 # 对左边部分执行快速排序
23 quick_sort(alist, start, left - 1)
24 # 对右边部分执行快速排序
25 quick_sort(alist, left + 1, end)
26
27 qlist = [49,38,65,48,24,31,62,79]
28 #qlist = [1, 12, 22, 34, 21, 4, 6, 8, 11, 54, 36, 7, 3, 0, 60, 62, 63]
29 quick_sort(qlist, 0, len(qlist) - 1)
30 print(qlist)


View Code

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]])


View Code

 


推荐阅读
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • Java 中的 BigDecimal pow()方法,示例 ... [详细]
  • Java 中 Writer flush()方法,示例 ... [详细]
  • Java 类成员初始化顺序与数组创建
    本文探讨了Java中类成员的初始化顺序、静态引入、可变参数以及finalize方法的应用。通过具体的代码示例,详细解释了这些概念及其在实际编程中的使用。 ... [详细]
  • 主要用了2个类来实现的,话不多说,直接看运行结果,然后在奉上源代码1.Index.javaimportjava.awt.Color;im ... [详细]
  • IneedtofocusTextCellsonebyoneviaabuttonclick.ItriedlistView.ScrollTo.我需要通过点击按钮逐个关注Tex ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • PyCharm中配置Pylint静态代码分析工具
    本文详细介绍如何在PyCharm中配置和使用Pylint,帮助开发者进行静态代码检查,确保代码符合PEP8规范,提高代码质量。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 本文介绍了如何使用 Spring Boot DevTools 实现应用程序在开发过程中自动重启。这一特性显著提高了开发效率,特别是在集成开发环境(IDE)中工作时,能够提供快速的反馈循环。默认情况下,DevTools 会监控类路径上的文件变化,并根据需要触发应用重启。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
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社区 版权所有