收集整理了一份《2024年最新物联网嵌入式全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升的朋友。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人
都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
进入正式内容之前,我们先了解下初阶常见的排序分类 :我们今天讲前四个!
🥗 1、直接插入排序
**基本思想:**当插入第i(i>=1)个元素时,前面的array[0],array[1],…,array[i-1]已经排好序,此时用array[i]的排 序码与array[i-1],array[i-2],…的排序码顺序进行比较,找到插入位置即将array[i]插入,原来位置上的元素顺序后移!
直接插入排序的特性总结:
元素集合越接近有序,直接插入排序算法的时间效率越高
时间复杂度:O(N^2) 、空间复杂度:O(1)
稳定性:稳定
void InsertSort(int* a, int n)
{
//直接插入排序 ———— 升序
for (int i = 0; i < n - 1; ++i)
{
int end = i;
int tmp = a[end + 1];
while (end >= 0)
{
if (a[i] > tmp) //如果比tmp大的话就往后移
{
a[end + 1] = a[end];
--end;
}
else //如果tmp比当前元素大的话就不需要交换位置了,直接跳出循环!
{
break;
}
}
a[end + 1] = tmp; // 最后把tmp放到比他小的元素后面!
}
}
🥙 2、希尔排序(缩小增量排序)
**基本思想:**先选定一个整数,把待排序文件中所有记录分成个组,所有距离为gap的记录分在同一组内,并对每一组内的记录进行排序。然后重复分组和排序的工作。当到达gap=1时,所有记录在统一组内排好序。
希尔排序的特性总结:
希尔排序是对直接插入排序的优化。
当gap > 1时都是预排序,目的是让数组更接近于有序。当gap == 1时,数组已经接近有序的 了,这样就会很快。这样整体而言,可以达到优化的效果。
希尔排序的时间复杂度不好计算,需要进行推导,推导出来平均时间复杂度: O(N^1.3— N^2)
稳定性:不稳定
void ShellSort(int* a, int n)
{
//希尔排序————升序
int gap = n;
while (gap > 1)
{
gap = gap / 2;
for (int 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 = end - gap;
}
else
{
break;
}
a[end + gap] = tmp;
}
}
}
}
🥪 3、直接选择排序
基本思想:
在元素集合array[i]–array[n-1]中选择关键码最大(小)的数据元素 若它不是这组元素中的最后一个(第一个)元素,则将它与这组元素中的最后一个(第一个)元素交换 在剩余的array[i]–array[n-2](array[i+1]–array[n-1])集合中,重复上述步骤,直到集合剩余1个元素。
直接选择排序的特性总结:(因为特别简单就不画图了直接上代码)
直接选择排序思考非常好理解,但是效率不是很好。实际中很少使用
时间复杂度:O(N^2) 、空间复杂度:O(1)
稳定性:不稳定
这里我们用一个优化版本,每次确定两个数的最终位置:
void Swap(int* p1, int* p2)
{
int tmp = *p1;
*p1 = *p2;
*p2 = tmp;
}
void SelectSort(int* a, int n)
{
int begin = 0;
int end = n - 1;
while (begin < end)
{
int min = begin;
int max = begin;
for (int i = begin; i <= end; ++i)
{
if (a[i] < a[min])
{
min = i;
}
if (a[i] > a[max])
{
max = i;
}
}
Swap(&a[min], &a[begin]);
if (max == begin) //如果max等于begin的话就证明最大值是begin的位置
//需要修正max的位置
{
max = min;
}
Swap(&a[max], &a[end]);
++begin;
--end;
**收集整理了一份《2024年最新物联网嵌入式全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升的朋友。**
![img](https://img-blog.csdnimg.cn/img_convert/81162f7bcacf5ffc0be7c3107ba40c4c.png)
![img](https://img-blog.csdnimg.cn/img_convert/564c200bbb8a18893e65ef4dd6662131.png)
**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618679757)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人**
**都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
436)]
[外链图片转存中...(img-PHUUNAyZ-1715636755436)]
**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618679757)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人**
**都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**