插入排序+希尔排序

目录

插入排序:

希尔排序:


插入排序:

注意这里不要将插入排序和冒泡排序弄混:

插入排序是将数据不断放入前一个有序数列:

cpp 复制代码
// 插入排序
void InsertSort(int* a, int n)
{
	for (int j =1; j < n; j++)
	{
		for (int i = j; i > 0; i--)
		{
			if (a[i] < a[i - 1])
			{
				int m = a[i - 1];
				a[i -1] = a[i];
				a[i] = m;
			}
			else
			{
				break;
			}
		}
	}	
}

希尔排序:

将插入排序进行多次实现,从高间距到低间距,最后到间距为1的插入排序:

如图我们将具有相同标记的方格记为一组,并分别对不同组进行插入排序,这样就会将序列变得比原来有序,这样不断进行,并不断缩小排序的间距。

这样再次进行排序将会变的更加有序,直到间距为1。间距为1时进行排序将变为插入排序,序列将完全有序。

target为间距

cpp 复制代码
// 希尔排序
void ShellSort(int* a, int n)
{
	int target=n/2;
	while (target)
	{

		for (int m = 0; m < target; m++)//实现多组排序
		{
			
			for (int j = m; j < n ; j += target)//单组排序
			{
				for (int i = j; i > target-1; i -= target)//这里不能是i>0,i-target最小为0
				{
					if (a[i] < a[i - target])
					{
						int m = a[i - target];
						a[i - target] = a[i];
						a[i] = m;
					}
					else
					{
						break;
					}
				}
			}
		}

		target /= 2;
	}	
}

当然这里我们进行三层循环有一些繁琐,这里我们可以改善成为两层循环:

也就是第一组进行一次插入排序,第二组进行一次插排序........不断前进

cpp 复制代码
// 希尔排序
void _ShellSort(int* a, int n)
{
	int target = n / 2;
	while (target)
	{

			for (int j = 0; j < n; j ++)//递进形式排序
			{
				for (int i = j; i > target - 1; i -= target)//这里不能是i>0,i-target最小为0
				{
					if (a[i] < a[i - target])
					{
						int m = a[i - target];
						a[i - target] = a[i];
						a[i] = m;
					}
					else
					{
						break;
					}
				}
			}
		target /= 2;
	}
}
相关推荐
xwz小王子42 分钟前
手术机器人登上Science Robotics:2毫米纤细手臂,从3厘米切口完成腰椎神经减压
算法·机器人
黎阳之光2 小时前
视频孪生智护供水生命线:黎阳之光赋能医疗与园区水务高质量升级
运维·物联网·算法·安全·数字孪生
Black蜡笔小新2 小时前
自动化AI算法训练服务器DLTM制造业AI质检工作站助力制造业实现AI智检
人工智能·算法·自动化
嵌入式小能手2 小时前
飞凌嵌入式ElfBoard-进程间的通信之命名管道
linux·服务器·算法
啦哈拉哈3 小时前
Leetcode题解记录-hot100(81-100)
算法·leetcode·职场和发展
csdn_aspnet3 小时前
Java 霍尔分区算法(Hoare‘s Partition Algorithm)
java·开发语言·算法
诸葛务农3 小时前
道路行驶条件下电动汽车永磁电机的有效使用寿命及永磁体的失效和回收再利用(下)
java·开发语言·算法
snow@li3 小时前
AI:理解 大数据、算法、算力、电力、生成式AI、token 之间的关系
大数据·人工智能·算法
小智老师PMP3 小时前
零基础能不能考PMP?零基础专属学习路径+全套扶持体系
学习·算法·职场和发展·软件工程·求职招聘·敏捷流程
Dillon Dong4 小时前
【风电控制】FPGA采集Vdc的ADC增益系数解析——从数字码到实际电压的桥梁
算法·fpga开发·变流器·风电控制