【数据结构 | 直接选择排序】

基本思路

直接插入排序(StraightInsertionSort)的基本操作是将一个记录插入到已经排好序的有序表中,从而得到一个新的、记录数增1的有序表。
在这里插入图片描述


我们可以同时从数组的头部和尾部同时进行排序工作:

我们首先使用maxmin 两个变量来记录最大和最小值,初始化同时为数组第一个数字
然后通过遍历整个数组,更新max和min
然后吧最小数交换至数组头部.吧最大数交换至数组尾部
缩短数组范围,再重复以上步骤,即可。

直接插入排序


在这里插入图片描述

按照以上步骤完成代码。
我们有如下数组需要排序
在这里插入图片描述



结果如下:

在这里插入图片描述

为什么出错了?
在这里插入图片描述



修改如下:
在这里插入图片描述
结果如下:
在这里插入图片描述

SelectSort

//直接插入排序
void SelectSort(int* a, int n)
{
   
	int begin = 0, end = n - 1, i;
	while (begin < end)
	{
   
		int min = begin, max = begin;
		//同时排头和尾
		for (i = begin + 1; i <= end; i++)
		{
   
			if (a[i] < a[min])
				min = i;
			if (a[i] > a[max])
				max = i;
		}
		Swap(&a[min], &a[begin]);
		if (begin != max)
		{
   
			Swap(&a[max], &a[end]);
		}

		begin++;
		end--;
	}
}

相关推荐

  1. 数据结构选择排序

    2024-01-18 22:44:03       39 阅读

最近更新

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

    2024-01-18 22:44:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-18 22:44:03       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-18 22:44:03       82 阅读
  4. Python语言-面向对象

    2024-01-18 22:44:03       91 阅读

热门阅读

  1. InnoDB底层的一些主要数据结构

    2024-01-18 22:44:03       55 阅读
  2. Docker守护进程是什么

    2024-01-18 22:44:03       57 阅读
  3. pyhton合并多个Excel文件

    2024-01-18 22:44:03       50 阅读
  4. uniapp如何实现跨端适配

    2024-01-18 22:44:03       62 阅读
  5. 数据库重点简答题

    2024-01-18 22:44:03       56 阅读
  6. Oracle修改端口总结

    2024-01-18 22:44:03       48 阅读
  7. Python连接打印机:实现自动化打印的利器

    2024-01-18 22:44:03       49 阅读
  8. LC 零矩阵

    2024-01-18 22:44:03       61 阅读
  9. Mybatis-plus多租户插件

    2024-01-18 22:44:03       57 阅读
  10. [蓝桥杯 2013 省 B] 翻硬币

    2024-01-18 22:44:03       51 阅读