C/C++ 快速排序的实现

代码如下:

#include<iostream>
using namespace std;
void qS(int *array,int left,int right){
  if(left<right){    //快速排序的终止条件,当仅剩下一个元素则结束快速排序
    int key=array[left];
    int low=left,high=right;
    while(low<high){
      while(key<=array[high]&&low<high){    //8~11操作是从右边依次比较左边的元素,将小于目标值的元素置于左边
        high--;
      }
      array[low]=array[high];
      while(key>=array[low]&&low<high){    //12~15操作是从左边依次比较右边的元素,将大于目标值的元素置于右边
        low++;
      }
      array[high]=array[low];
    }
    array[low]=key;              //将目标值放置在空位,此时一轮快速排序结束,目标值的左边全部是小于他的,右边全部是大于它的
    qS(array,left,low-1);       //将目标值的左边元素集再进行快速排序
    qS(array,low+1,right);      //将目标值的右边元素集再进行快速排序
  }
}

int main() {
  int arr[]={33,14,2,444,23,444,132,55,0};
  qS(arr,0,sizeof(arr)/sizeof(arr[0]-1));
  for(int i=0;i<sizeof(arr)/sizeof(arr[0]);++i){
    cout<<arr[i]<<' ';
    }
  return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值