C 语言快速排序最好情况时间复杂度是 nlog2n,怎么理解

快速排序最好的情况是每次把上一次的数组平均分成两个子数组。

设数组总数一共为n,如果把这n个数每次分成2半最后每个数组只包含一个元素,假设要分k次,则2的k次方=n,解得k=log2 n(log以2为底对n取对数).也就是说要分log2 n次,而每次都是处理n个数据。所以总的时间复杂度为O(n*log2 n)。

  • 9
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用快速选择算法(Quickselect algorithm),它是快速排序算法的一个变种。它通过选取一个主元(pivot)将序列分成两个子序列,然后递归地在其中一个子序列中继续查找,直到找到第k大的元素。 以下是使用快速选择算法实现在n个无序序列元素中找到第k大的元素的C++代码: ```c++ #include <iostream> #include <vector> #include <algorithm> using namespace std; int partition(vector<int>& nums, int left, int right) { int pivot = nums[right]; int i = left - 1; for (int j = left; j < right; j++) { if (nums[j] <= pivot) { i++; swap(nums[i], nums[j]); } } swap(nums[i + 1], nums[right]); return i + 1; } int quickselect(vector<int>& nums, int left, int right, int k) { if (left == right) return nums[left]; int pivotIndex = partition(nums, left, right); if (k == pivotIndex) return nums[k]; else if (k < pivotIndex) return quickselect(nums, left, pivotIndex - 1, k); else return quickselect(nums, pivotIndex + 1, right, k); } int findKthLargest(vector<int>& nums, int k) { int n = nums.size(); return quickselect(nums, 0, n - 1, n - k); } int main() { vector<int> nums = { 3, 2, 1, 5, 6, 4 }; int k = 2; cout << "The " << k << "th largest element is " << findKthLargest(nums, k) << endl; return 0; } ``` 在这个实现中,`partition`函数用于选取主元,并将序列分成两个子序列;`quickselect`函数利用递归查找第k大的元素;`findKthLargest`函数是对`quickselect`函数的封装。 时间复杂度nlog2n,因为每次递归都会将序列分成两个子序列,每个子序列的大小最多为原序列大小的一半,所以递归层数最多为log2n。每一层递归的时间复杂度为线性的,所以总的时间复杂度nlog2n
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值