C++写选择排序+图解

一、选择排序步骤

  1. 画大饼:未排序前,在数组中选定第一个元素作为最小值或最大值(最小值升序排列,最大值升降序),注意,这里的最小值是给一个数组下标的标识。
  2. 见风使舵:为了描述清楚,就以升序为例,也就是,未排序前,选定第一个元素为最小值。每轮排序将除剩余的数组元素与选定的最小值进行比较,一旦出现比选定的最小值还要小的元素,就将其选定为新的最小值,把下标给这个新的最小值(也就是交换下标)。
  3. 一锤定音:比较一轮过后,把真正的最小值,与选定的最小值元素作交换。然后,将第一个元素视作已排序。
  4. 接着奏乐接着舞:第二轮比较,从第二个元素开始,重复以上第2步和第3步,直到比较完素组里面所有的元素。

二、 选择排序图解

示例:int arr[4] = {3, 2, 1, 0};

7c88c62c3a45464698eb521e51565c0c.png

 三、代码

#include<iostream>
using namespace std;
//选择排序 升序
void selectSort(int arr[], int& length)
{
	//输出排序前数组元素:
	cout << "没有排序前:";
	cout << arr[0] << arr[1] << arr[2] << arr[3] << endl;
	int i = 0, j = i;
	for (i = 0; i < length; i++)
	{
		//假定最小数
		int min = i;
		//从数组元素的第二位开始和选定最小值比较
		for (j = i + 1; j < length; j++)
		{
			//如果出现比选定最小值还要小的数
			if (arr[j] < arr[min])
			{
				//下标交换
				//交换 已知最小值 和 选定最小值 的下标
				min = j;
			}
			//元素交换
			//比较一轮过后,交换真正的最小值元素和选定的最小值元素
			int temp = arr[i];
			arr[i] = arr[min];
			arr[j] = temp;

			//(方便看每次交换的过程)
			cout << "第" << "j =   " << j << "轮交换:";
			cout << arr[0] << arr[1] << arr[2] << arr[3] << endl;
		}
		//(方便看每轮排序的结果)
		cout << "第" << "i+1 = " << i + 1 << "轮结果:";
		cout << arr[0] << arr[1] << arr[2] << arr[3] << endl;
		cout << endl;
	}
}
//打印最终排序结果
void printSortRet(int arr[], int& length)
{
	cout << "最终排序结果:";
	for (int i = 0; i < length; i++)
	{
		cout << arr[i];
	}
	cout << endl;
}
int main()
{
	int arr[] = { 3, 2, 1, 0 };
	int length = sizeof(arr) / sizeof(arr[0]);
	selectSort(arr, length);
	printSortRet(arr, length);
	system("pause");
	return 0;
}

运行结果:

ca029909c12945da8165860d45c7c6db.png

四、参数解析

  • i为排序轮数。
  • min为未排序元素中选定最小值下标。
  • j是与比较的次数,也就是所有元素都与选定的最小值相比较,所以j从1开始。

最后,欢迎各位朋友指正以及交流经验 !

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爬爬pua

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值