C++语言编写快速排序算法

快速排序是一种高效的排序算法,它通过递归分治的方式将数组分为两个部分,对这两个部分分别排序,从而达到整个数组的排序。

以下是一个C++代码实现快速排序的示例:

#include <iostream>
#include <vector>

void quick_sort(std::vector<int> &nums, int left, int right) {
  if (left >= right) {
    return;
  }
  int pivot = nums[left];
  int i = left, j = right;
  while (i < j) {
    while (i < j && nums[j] >= pivot) {
      j--;
    }
    nums[i] = nums[j];
    while (i < j && nums[i] <= pivot) {
      i++;
    }
    nums[j] = nums[i];
  }
  nums[i] = pivot;
  quick_sort(nums, left, i - 1);
  quick_sort(nums, i + 1, right);
}

int main() {
  std::vector<int> nums = {5, 4, 3, 2, 1};
  quick_sort(nums, 0, nums.size() - 1);
  for (int num : nums) {
    std::cout << num << " ";
  }
  std::cout << std::endl;
  return 0;
}

上述代码中,quick_sort函数实现了快速排序算法。它接受一个数组和排序的左右边界作为参数,在函数内部递归地排序数组。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值