蓝桥杯 经典算法题 实现快速排序

题目:

题解:

快速排序其实每次不是将大区间平均分为两个子区间(这个与每次选取的基准值有关),而是每次将区间分为全大于基准值和全小于基准值两个子区间,然后又分别在子区间中再找一个基准值再分为两个子区间如此往复最终将整个数组变得有序。

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int arr[105]={0};
void quik_sort(int l,int r){
  if(r-l<=0)return ;
  else if(r-l==1){
    if(arr[r]<arr[l]){
      swap(arr[r],arr[l]);
    }
    return ;
  }
  int ind=arr[l];
  int x=l,y=r;
  while(x!=y){
    while(x!=y&&arr[y]>=ind)y--;
    swap(arr[y],arr[x]);
    while(x!=y&&arr[x]<ind)x++;
    swap(arr[y],arr[x]);
  }
  arr[x]=ind;
  quik_sort(l,x);
  quik_sort(x+1,r);
}

int main(){
  int n;
  cin>>n;
  for(int i=0;i<n;i++)cin>>arr[i];
  quik_sort(0,n-1);
  for(int i=0;i<n;i++)cout<<arr[i]<<" ";
  return 0;
}

题后反思:

如何将一个数组变为两部分左半部分全部小于右半部分:

一个最简单朴素的方法是选择第一个值作为基准值并将第一个位置空出来,然后利用左右指针,当空位在左指针时用右指针找一个小于基准值的值与左指针交换,当空位在右指针时用左指针找一个大于等于基准值的值与左指针交换,知道左右指针重合然后将基准值填到这个位置上即可。

最后终止条件的判断:

第一写的是:

cpp 复制代码
if(r-l=0)return ;

然后一直报错找不到原因,因为当基准值本来因该填在最后一个位置时,x和y都指向序列的末尾,然后下一次调用时范围为(nums.size()-1,nums.size())是一个不合理的区间,这种情况因该停止排序,但是程序无法识别到,所以报错。因此要根据具体实现充分考虑因该终止时的情况。

相关推荐
小羊在睡觉1 小时前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
3DVisionary1 小时前
蓝光三维扫描:医疗制造的精度焦虑怎么解
人工智能·算法·制造·蓝光三维扫描·医疗制造·三维检测·义齿检测
jiayong231 小时前
面试中遇到不熟悉问题的应对策略深度解析
面试·职场和发展
好评笔记1 小时前
机器学习面试八股——常用损失函数
人工智能·深度学习·算法·机器学习·校招
weixin_468466851 小时前
全局与局部注意力机制新手实战指南
人工智能·python·深度学习·算法·自然语言处理·transformer·注意力机制
_日拱一卒2 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
珂朵莉MM2 小时前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--束搜索
人工智能·算法
Omics Pro3 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
JAVA社区3 小时前
Java高级全套教程(十)—— SpringCloudAlibaba超详细实战详解
java·开发语言·spring cloud·面试·职场和发展
voidmort3 小时前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想
python·深度学习·算法