排序算法学习记录-快速排序

快速排序

快速排序关键在于确定一个中间值,使得小于这个中间值的数在左边,大于这个中间值的数在右边。那么中间值该如何确定呢?有以下几种做法

  • 首元素,也就是arr[l]
  • 尾元素,也就是arr[r]
  • 中间元素,也就是arr[(l+r)>>1]这里是位运算,等价于arr[(l+r)/2^1]
  • 中间的一个随机元素
c 复制代码
void Qsort(int arr[],int l,int r){
	if(l>=r) return;
	int begin = l,end = r,x = arr[(l+r)>>1];
	//上面是位运算,表示(l+r)/2^1
	while(begin<=end){
		while(arr[begin]<x) begin++;
		while(arr[end]>x) end--;
		if(begin<=end) swap(&arr[begin++],&arr[end--]);
	}
	Qsort(arr,l,end);Qsort(arr,begin,r);
}
//除了和x的比较不带=,其他的都带

快速排序相关变体

题目如下:

求第k大(小)的数,一种做法是堆排序把前k个数找出来就行,另一种就是利用快速排序的思想去做。现暂把中间的分界点称为pivot,左边的数都小于pivot,右边的数都大于pivot。那么假如左边有m个数,右边有n个数。求第k大的数。如果k<n,那么这个数肯定在右边,反之这个数肯定在左边。以此来缩小这个数所在的范围。

归并排序

归并排序的核心思想在于将两个有序的数组合并为一个全局有序的数组。

c 复制代码
int tmp[100000];
void merge_sort(int arr[],int begin,int end){
    if(begin>=end) return;
    int mid = (begin+end)>>1;
    merge_sort(arr,begin,mid);
    merge_sort(arr,mid+1,end);
    int l_begin = begin,r_begin = mid+1,tmp_index = 0;
    while(l_begin<=mid && r_begin<=end)
    {
        if(arr[l_begin]<=arr[r_begin]) tmp[tmp_index++] = arr[l_begin++];
        else tmp[tmp_index++] = arr[r_begin++];
    }
    while(l_begin<=mid) tmp[tmp_index++] = arr[l_begin++];
    while(r_begin<=end) tmp[tmp_index++] = arr[r_begin++];
    int k = 0;
    while(begin<=end){
        arr[begin++] = tmp[k++];
    }
}
相关推荐
CoovallyAIHub14 小时前
语音AI Agent编排框架!Pipecat斩获10K+ Star,60+集成开箱即用,亚秒级对话延迟接近真人反应速度!
深度学习·算法·计算机视觉
木心月转码ing16 小时前
Hot100-Day14-T33搜索旋转排序数组
算法
会员源码网18 小时前
内存泄漏(如未关闭流、缓存无限增长)
算法
颜酱19 小时前
从0到1实现LFU缓存:思路拆解+代码落地
javascript·后端·算法
颜酱20 小时前
从0到1实现LRU缓存:思路拆解+代码落地
javascript·后端·算法
CoovallyAIHub2 天前
Moonshine:比 Whisper 快 100 倍的端侧语音识别神器,Star 6.6K!
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
速度暴涨10倍、成本暴降6倍!Mercury 2用扩散取代自回归,重新定义LLM推理速度
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
实时视觉AI智能体框架来了!Vision Agents 狂揽7K Star,延迟低至30ms,YOLO+Gemini实时联动!
算法·架构·github
CoovallyAIHub2 天前
开源:YOLO最强对手?D-FINE目标检测与实例分割框架深度解析
人工智能·算法·github