[数据结构]插入排序(全)

插入排序分为直接插入排序和希尔排序,希尔排序是在直接插入排序的基础上做出的优化版本(原因后面解释)。

代码如下:

cpp 复制代码
//直接插入排序
void InsertSort(int arr[], int sz)
{
	for (int i = 0; i < sz - 1; i++)
	{
		int mark = i;
		int tmp = arr[mark + 1];
		while (mark >= 0)
		{
			if (tmp < arr[mark])
			{
				arr[mark + 1] = arr[mark--];
			}
			else
			{
				break;
			}
			arr[mark + 1] = tmp;
		}
	}
}
//希尔排序
void ShellSort(int arr[], int sz)
{
	int gap = sz;
	while (gap > 1)
	{
		gap = gap / 3 + 1;
		for (int i = 0; i < sz - gap; i++)
		{
			int mark = i;
			int tmp = arr[mark + gap];
			while (mark >= 0)
			{
				if (tmp < arr[mark])
				{
					arr[mark + gap] = arr[mark];
					mark -= gap;
				}
				else
				{
					break;
				}
				arr[mark + gap] = tmp;
			}
		}
	}
}
//打印数组
void Print(int arr[], int sz)
{
	for (int i = 0; i < sz; i++)
	{
		printf("%d ", arr[i]);
	}
	printf("\n");
}

头文件:

cpp 复制代码
#pragma once
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
void InsertSort(int arr[], int sz);
void ShellSort(int arr[], int sz);
void Print(int arr[], int sz);

测试:

因为直接插入排序时间复杂度最好是O(n),最坏是O(n^2),最坏情况是排序对象是降序排列的,希尔通过把排列对象划分成若干部分,这些部分内部进行直接插入排序,粗略把排序对象排列成升序,从而优化排序过程,也即是希尔把直接插入排序的最坏情况避免了。

谢谢观看!

相关推荐
学习路上_write1 天前
STM32回调函数使用/定时器/GPIO/串口/
c语言·单片机·嵌入式硬件
立志成为大牛的小牛1 天前
数据结构——三十七、关键路径(王道408)
数据结构·笔记·程序人生·考研·算法
czy87874751 天前
C语言实现状态模式
c语言·状态模式
czy87874751 天前
C语言实现迭代器模式
c语言·迭代器模式
GilgameshJSS1 天前
STM32H743-ARM例程36-DNS
c语言·arm开发·stm32·单片机·嵌入式硬件
Shinom1ya_1 天前
算法 day 41
数据结构·算法·leetcode
无敌最俊朗@1 天前
C++ 值类别与移动语义详解(精简版)
java·数据结构·算法
czy87874751 天前
C语言实现策略模式
c语言·排序算法·策略模式
岑梓铭1 天前
《考研408数据结构》第六章(5.5树的应用)复习笔记
数据结构·笔记·考研·408·ds
不觉晚秋1 天前
极限挑战之一命速通哈夫曼树
c语言·数据结构··哈夫曼树