面试需要掌握的排序 Quick Sort and Merge Sort 快速排序和归并排序 [Java]

本文主要探讨了在面试中常被问到的两种排序算法——快速排序和归并排序。当需要排序10,000个元素时,快速排序的时间复杂度为O(N^2),而归并排序的时间复杂度为O(N*logN),更优。虽然归并排序需要额外的内存空间,但在处理大数据时更为实用。" 85485120,3838679,C++实现轻量级关键词查找系统,"['算法', '数据结构', 'C++编程', '字符串处理']
摘要由CSDN通过智能技术生成

if N (the number of items to be sorted) is 10,000, then N^2 is 100,000,000, while N*logN is only 40,000. If sorting this many items required 40 seconds with the mergesort, it would take almost 28 hours for the insertion sort.

Part 1 Quick Sort 快速排序

快速排序的算法没有什么可以多说的。但有一点需要提及就是partition函数的重要性。partition的应用场景很多,例如把文件分成大于1G的和小于1G的,把班里同学分成身高高于170cm的和小于170cm的等等。
另外partition还可以解决一类面试题(第k大的数),例如:
1. 最小的k个数,时间复杂度是O(N)
2. 数组中次数超过一半的数,时间复杂度是O(N)
解法都是不断的缩小partition的范围,直到partition返回值为k时停止,即找到了第k大的数。时间复杂度O(N)需要数学公式推理,记住答案吧少年。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值