c语言插入排序及希尔排序详解

目录

前言:

插入排序:

希尔排序:


前言:

排序在我们生活中无处不在,比如学生成就排名,商品价格排名等等,所以排序在数据结构的学习中尤为重要,今天就为大家介绍两个经典的排序算法:插入排序和希尔排序。

插入排序:

思路图:

思路:

从第二个元素开始和前面的元素依次比较,如果前面的元素比它大,则将该元素移到后一位,如果该元素比它小,则直接插入该元素后面。

代码实现:

复制代码
void InsertSort(int* a, int n)
{
	int i = 0;
	for (i = 0;i < n-1;i++)
	{
		int end = i;
		int tmp = a[end + 1];
		while (end >= 0)
		{
			if (a[end] > tmp)
			{
				a[end + 1] = a[end];
				end--;
			}
			else
			{
				break;
			}
		}
		a[end + 1] = tmp;
	}
}

时间复杂度:

最坏情况下为O(N*N),此时待排序列为逆序,或者说接近逆序
  最好情况下为O(N),此时待排序列为升序,或者说接近升序。
空间复杂度:O(1)

希尔排序:

其实希尔排序就是插入排序的进阶版,可以说是希尔对插入排序进行了优化。

思路图:

思路:

步骤一:预排序,使数组接近有序

步骤二:插入排序

先将每间隔gap个元素的数据分为一组,将每组分别进行插入排序,使其接近有序

gap逐渐减小,gap减为1时就是进行步骤二的插入排序。

代码实现:

复制代码
void ShellSort(int* a, int n)
{
	int gap = n;
	while(gap>1)
	{
		gap = gap / 2;
		int i = 0;
		for (i = 0;i < n - gap; i++)
		{
			int end = i;
			int tmp = a[end + gap];
			while (end >= 0)
			{
				if (a[end] > tmp)
				{
					a[end + gap] = a[end];
					end -= gap;
				}
				else
				{
					break;
				}
			}
			a[end + gap] = tmp;
		}
	}
}

纸上得来终觉浅,绝知此事要躬行。快去实践一下吧。

相关推荐
AI算法沐枫7 小时前
深度学习python代码处理科研测序数据
数据结构·人工智能·python·深度学习·决策树·机器学习·线性回归
m0_629494739 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户9 小时前
用队列实现栈
数据结构·算法
做人求其滴9 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
daad7779 小时前
记一组无人机IMU传感器数据
算法
计算机安禾9 小时前
【c++面向对象编程】第42篇:模板特化与偏特化:为特定类型定制实现
开发语言·c++·算法
小O的算法实验室9 小时前
2026年KBS,流形感知强化学习差分进化算法+不规则3D无人机路径规划,深度解析+性能实测
算法·智能算法·智能算法改进
玖釉-10 小时前
C++ 中的循环语句详解:while、do...while、for、嵌套循环与循环控制
开发语言·c++·算法
不做无法实现的梦~10 小时前
运动控制系统复习一览-----常考题目总结版本
算法
小短腿的代码世界10 小时前
信号路由风暴:Qt算法交易系统的高频信号分发架构
qt·算法·架构