快速排序模板及其理解

快速排序在面试中经常用于考察面试者的代码能力,以下是我个人对如何手撕快排的一些理解:

原理:

快速排序的解决分为两个部分,分区(partition)和递归(recurse)。

分区是主要进行排序的功能,递归用于控制分区的次数。

分区的思想是:选定一个数,将所有小于这个数的数组元素都放在它的左侧,同理所有大于这个数的数组元素都放在它的右侧。此时,这个数在数组中就是有序的,它处于它应该在的位置。接下来对其左侧的区间进行分区:同样也是选定一个数……,右侧区间同理。一直进行分区这个操作,直到这个区间只有一个数,也就代表这个区间的父区间排序完毕。了解了快速排序的流程后,不难看出它和二叉树的遍历很像,每个区间二分进行分区并排序,就是二叉树遍历所有子节点并打印。

实现思路:

int partition(int l, int r){ // 分区函数
	int mid = nums[r]; // 选取最右侧的数组元素为界
	int fast = l, slow = l; // 定义快慢指针
	while(fast < r){
		if (nums[fast] < mid){
			swap(nums[fast], nums[slow]); // 将比mid小的放在slow指针的左边
			slow++; // slow右移,此时slow左侧的元素都比mid小
		}
		fast++;
	}
	swap(nums[r], nums[slow]); // 将mid与slow交换,此时该数组以mid为界,左边都比mid小,右边都比mid大
//  打印调试过程
//	for (int i = l;i < r;i++) cout << nums[i] << ' ';
//	cout << endl;
	return slow; // 返回mid的索引
}
void qsort(int l, int r){
	if (r > l){
		int mid = partition(l, r); // mid已经有序,以mid为基准
		qsort(l, mid - 1); // 对于mid左边的区域进行分区
		qsort(mid + 1, r); // 对于mid右边的区域进行分区
	} else return;
}

流程理解:

首先,我们输入一个数组,例如:

int nums[6] = {5, 3, 1, 6, 2, 4};

为了方便函数读取,我们将这个数组设置为全局变量(如果将nums设置在main函数中,在定义函数时同时将数组的地址传入也可)。

易知数组的l,r分别为0,5,在主函数中执行:

qsort(0, 5);

此时进行第一次的partition,我们默认取区间右边界的数为mid,也就是将4作为界。然后定义快慢指针,初始值都是l,使用while循环,每次循环快指针都往右走,一直走到r结束。

在快指针往右走的过程中,判断其遍历到的每一个数,如果这个数比mid小,那么就将这个数与慢指针指向的数位置互换。位置互换后,慢指针再右移一位。

以上这个操作,将使得原区间中所有比mid小的数,都在慢指针的左侧。慢指针所在的位置,就是mid应该处于的位置。所以最后将mid与慢指针指向的数位置交换,分区操作就完成了。

接下来以mid为界,不断划分区间进行递归:

qsort(l, mid - 1);
qsort(mid + 1, r);

直到划分为长度为1的区间,此时排序就算完成了,最后输出即可。

手撕思路:

1. 实现分区,分区需要快慢指针,快指针负责遍历,将所有比mid小的数都给慢指针;

2. 实现递归,左区间qsort,右区间qsort,返回条件为区间长度小于等于1;

  • 8
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 蓝桥杯Python大学B组的高频考点有以下几个: 1. 数据类型:包括整数、浮点数、字符串、列表、字典等。重点掌握它们的基本操作方法,如索引、切片、增删改查等。 2. 条件语句与循环结构:if语句和for循环是编程中常用的控制流程语句,灵活运用它们可以实现不同的功能。 3. 函数:函数是将一段可重复使用的代码块封装起来,以供其他部分调用。理解函数的定义、调用、参数传递等基本概念,并能熟练运用。 4. 文件操作:读取和写入文件是程序与外部环境数据交互的重要方式,要能够使用open()函数打开文件、读取文件内容,以及写入文件等操作。 5. 异常处理:处理程序运行时可能出现的异常情况,如文件不存在、除零错误等。了解常见的异常类型,并能使用try-except语句进行异常处理。 6. 面向对象编程:理解类与对象的概念,了解如何定义类及其属性和方法,以及如何创建和使用对象。 7. 模块与库的使用:Python拥有丰富的第三方库和模块,能够快速地解决一些常见问题。掌握如何导入、调用和使用这些库和模块,能够提高编程效率。 以上这些是蓝桥杯Python大学B组的高频考点模板,希望能对你备考有所帮助。 ### 回答2: 蓝桥杯Python大学B组高频考点模板主要包括基础语法、数据类型、运算符、流程控制、函数、模块、文件操作、异常处理等。 首先,基础语法是我们使用Python语言的基础,包括变量的定义、常量、注释、输入输出等。在考试中,可能会涉及到变量的命名、关键字的使用、注释的添加等方面。 其次,数据类型是Python中非常重要的概念,包括整数、浮点数、字符串、列表、元组、字典等。在考试中,我们需要熟练掌握各种数据类型的定义、常用操作和方法。 第三,运算符是Python中用于数学运算和逻辑运算的符号,包括算术运算符、比较运算符、逻辑运算符等。我们需要理解运算符的优先级、使用方法以及对应的运算规则。 第四,流程控制是Python中实现程序逻辑分支和循环执行的重要方法,包括条件语句和循环语句。我们需要掌握if语句、for循环、while循环等的基本语法和用法。 第五,函数是Python中封装代码的方式,可以重复使用,提高代码的复用性。在考试中,我们需要了解函数的定义、参数传递、返回值等方面的知识。 第六,模块是用于组织代码的方式,将相关的功能代码放在一个文件中。我们需要了解如何导入模块、调用模块中的函数等。 第七,文件操作是Python中读写文件的操作,包括打开文件、读取文件内容、写入文件等。在考试中,我们需要熟悉文件的打开方式、读取方式、写入方式等。 最后,异常处理是处理程序在运行过程中可能发生的错误的方式。我们需要了解如何使用try-except语句捕获和处理异常,以及常见的异常类型。 通过熟练掌握以上高频考点模板,我们可以提高在蓝桥杯Python大学B组考试中的答题效率和准确性。但需要注意的是,除了掌握模板,实际的编程能力和解决问题的能力同样重要。 ### 回答3: 蓝桥杯Python大学B组高频考点模板主要有以下几个方面: 1. 基础语法:Python的基本语法包括变量、数据类型、运算符、控制流等。考生需要熟悉Python的语法规则,包括正确使用变量、常量,运用不同的数据类型进行计算等。 2. 函数与模块:Python内置了许多常用函数和模块,如输入输出函数、数学函数、字符串处理函数等。考生需要了解这些函数的使用方法,能够正确调用函数和模块,解决实际问题。 3. 文件操作:Python提供了操作文件的函数和方法,包括文件的打开、读取、写入、关闭等。考生需要熟悉文件操作的流程和常用函数,能够完成文件的读写和处理。 4. 数据结构算法:考生需要掌握Python中常用的数据结构算法,如列表、字典、集合、排序算法、查找算法等。能够灵活运用这些数据结构算法解决问题,并考虑算法的时间复杂度和空间复杂度。 5. 异常处理:Python中提供了异常处理机制,能够捕获和处理程序运行过程中出现的异常。考生需要了解常见的异常类型和异常处理语句,合理处理程序中可能出现的异常情况,确保程序的健壮性和稳定性。 6. 面向对象编程:Python是一门面向对象的编程语言,考生需要掌握类的定义、实例化、继承、多态等基本概念和操作。能够基于面向对象的思想设计和实现程序,提高代码的复用性和可维护性。 希望以上内容能够对您有所帮助。如果还有其他问题,请继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值