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

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

代码如下:

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),最坏情况是排序对象是降序排列的,希尔通过把排列对象划分成若干部分,这些部分内部进行直接插入排序,粗略把排序对象排列成升序,从而优化排序过程,也即是希尔把直接插入排序的最坏情况避免了。

谢谢观看!

相关推荐
鹿鹿学长14 小时前
2025年全国大学生数学建模竞赛(C题) 建模解析|婴儿染色体数学建模|小鹿学长带队指引全代码文章与思路
c语言·开发语言·数学建模
伴杯猫14 小时前
【ESP32-IDF】基础外设开发2:系统中断矩阵
c语言·单片机·嵌入式硬件·mcu·物联网·github
Want59516 小时前
C/C++圣诞树①
c语言·开发语言·c++
bkspiderx17 小时前
C++经典的数据结构与算法之经典算法思想:贪心算法(Greedy)
数据结构·c++·算法·贪心算法
l1t18 小时前
轻量级XML读写库Mini-XML的编译和使用
xml·c语言·解析器
中华小当家呐18 小时前
算法之常见八大排序
数据结构·算法·排序算法
tju新生代魔迷19 小时前
数据结构:双向链表
数据结构·链表
小莞尔19 小时前
【51单片机】【protues仿真】基于51单片机停车场的车位管理系统
c语言·开发语言·单片机·嵌入式硬件·51单片机
xianyinsuifeng20 小时前
Oracle 10g → Oracle 19c 升级后问题解决方案(Pro*C 项目)
c语言·数据库·oracle
songx_9920 小时前
leetcode9(跳跃游戏)
数据结构·算法·游戏