D1.排序

1.快速排序 双指针

采用分治的思想,基于一个数作为标准,进行分治
步骤:

  1. 确定分界点的值。x = q[l]、q[(l+r)/2]、q[r]、随机 都可以;
  2. 划分区间:使得小于等于x的数放在数组的左边;大于等于x的数放在数组的右边;划分区间的结果不是有序的,只是满足了以上条件;
  3. 递归处理数组的左右部分;
    在这里插入图片描述
void quick_sort(int q[], int l, int r)
{
	if(r <= l) return;
	//两个指针i、j
	int i = l - 1, j = r + 1, x = q[(i+j)/2];
	while(i < j)
	{
		do i++; while( q[i] < x );
		do j--; while( q[j] > x );
		if( i < j ) swap( q[i] ,q[j] );
	}
	quick_sort( q, l, j );
	quick_sort( q, j + 1, r );
}

2.归并排序 双指针

采用分治的思想,步骤:

  1. 划分区域。确定分界点下标min = (l + r) / 2,将数组划分成左右两部分
  2. 排序。递归排序数组的左右两部分->有序
  3. 归并,合二为一。合并左右有序序列,形成完整的有序数组

在这里插入图片描述

using naamespace std;

const int N = 100010;
int q[N], temp[N];//需要额外的储存空间
void merge_sort(int q[], int l, int r)
{
	if(r <= l) return;
	
	//递归排序
	int mid = (l + r) / 2;
	merge_sort(q, l, mid);
	merge_sort(q, mid+1, r);
	
	//归并
	int i = l, j = mid+1;
	int k = 0;//结果数组的下标
	while(i <= mid && j <= r)
	{
		if(q[i] <= q[j]) temp[k++] = q[i++];
		else temp[k++] = q[j++];
	}
	while(i <= mid) temp[k++] = q[i++];
	while(j <= r) temp[k++] = q[j++];

	//copy
	for(i = 0,j = l; j <= r; i++,j++)
		q[j] = temp[i];
}

相关推荐

  1. <span style='color:red;'>D</span><span style='color:red;'>1</span>.<span style='color:red;'>排序</span>

    D1.排序

    2024-07-11 05:28:03      21 阅读
  2. 排序算法1

    2024-07-11 05:28:03       28 阅读
  3. 2404d,d语言1月会议

    2024-07-11 05:28:03       29 阅读
  4. 算法学习1——排序算法(1

    2024-07-11 05:28:03       20 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-11 05:28:03       53 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-11 05:28:03       55 阅读
  3. 在Django里面运行非项目文件

    2024-07-11 05:28:03       46 阅读
  4. Python语言-面向对象

    2024-07-11 05:28:03       56 阅读

热门阅读

  1. Leetcode 1143. Longest Common Subsequence

    2024-07-11 05:28:03       22 阅读
  2. 从像素角度出发使用OpenCV检测图像是否为彩色

    2024-07-11 05:28:03       25 阅读
  3. ES索引模板

    2024-07-11 05:28:03       17 阅读
  4. ”极大似然估计“和”贝叶斯估计“思想对比

    2024-07-11 05:28:03       20 阅读
  5. 理解Gunicorn:Python WSGI服务器的基石

    2024-07-11 05:28:03       21 阅读
  6. C++函数模板学习

    2024-07-11 05:28:03       15 阅读
  7. 探索Perl的自动清洁工:垃圾收集机制全解析

    2024-07-11 05:28:03       18 阅读
  8. Kruskal

    2024-07-11 05:28:03       20 阅读
  9. C++入门

    C++入门

    2024-07-11 05:28:03      18 阅读