选择排序(直接选择排序和堆排序)

server/2024/9/22 21:20:40/

一、直接选择排序

1.基本思想

每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完。

2.动图展示

3.思路讲解

①在元素集合array[i]—array[n-1]中选择关键码最大(小)的数据元素。

②若它不是这组元素中的最后一个(第一个)元素,则将它与这组元素中的最后一个(第一个)元素交换。

③在剩余的array[i]—array[n-2](array[i+1]—array[n-1])集合中,重复上述步骤,直到集合剩余1个元素。

4.代码展示

void Swap(int* p1, int* p2)
{int tmp = *p1;*p1 = *p2;*p2 = tmp;
}
void SelectSort(int* a, int n)
{int begin = 0, end = n - 1;while (begin < end){int mini = begin, maxi = begin;for (int i = begin + 1; i <= end; ++i){if (a[i] > a[maxi]){maxi = i;}if (a[i] < a[mini]){mini = i;}}Swap(&a[begin], &a[mini]);if (begin == maxi)maxi = mini;Swap(&a[end], &a[maxi]);++begin;--end;}
}

5.直接选择排序特性总结

①直接选择排序思考非常好理解,但是效率不是很好,实际中很少使用。

②时间复杂度:O(N^2),最好情况和最坏情况都是O(N^2)。

③空间复杂度:O(1)。

④稳定性:不稳定。

二、堆排序

《二叉树》(二)讲解堆

1.基本思想

堆排序(Heapsort)是指利用堆积树(堆)这种数据结构所设计的一种排序算法,它是选择排序的一种。它是通过堆来进行选择数据。需要注意的是排升序要建大堆,排降序建小堆。

①建堆:升序建大堆,降序建小堆(若降序建大堆,关系全乱了)。

②利用堆删除思想进行排序。

建堆和堆删除都用到了向下调整,因此需要掌握向下调整,就可以完成堆排序。

2.图片演示

3.代码展示

#include<stdio.h>
void Swap(int* p1, int* p2)
{int tmp = *p1;*p1 = *p2;*p2 = tmp;
}
void AdjustDown(int* a, int n, int parent)
{// 先假设左孩子小int child = parent * 2 + 1;while (child < n){// 找出小的那个孩子if (child + 1 < n && a[child + 1] < a[child]){++child;}if (a[child] < a[parent]){Swap(&a[child], &a[parent]);parent = child;child = parent * 2 + 1;}else{break;}}
}
void HeapSort(int* a, int n)
{for (int i = (n - 1 - 1) / 2; i >= 0; i--){AdjustDown(a, n, i);}int end = n - 1;while (end > 0){Swap(&a[0], &a[end]);AdjustDown(a, end, 0);--end;}
}
void TestHeap2()
{int a[] = { 4,2,8,1,5,6,7,9,3 };HeapSort(a, sizeof(a) / sizeof(int));for (int i = 0; i < sizeof(a) / sizeof(a[0]); i++){printf("%d ", a[i]);}
}
int main()
{TestHeap2();return 0;
}

4.堆排序特性总结

①堆排序使用堆来选数,效率就高了很多。

②时间复杂度:O(N*logN)

③空间复杂度:O(1)

④稳定性:不稳定


http://www.ppmy.cn/server/104129.html

相关文章

Jakarta Servlet 到 SpringMVC

Jakarta EE&#xff08;曾被称为Java EE&#xff09;是Java平台企业版&#xff08;Java Platform Enterprise Edition&#xff09;的下一代版本&#xff0c;它在Oracle将Java EE的开发和维护交给Eclipse Foundation后得以重生&#xff0c;并更名为Jakarta EE。Jakarta EE保留了…

算法的学习笔记—树的子结构(牛客JZ26)

&#x1f600;前言 在算法面试中&#xff0c;二叉树相关的问题经常出现&#xff0c;其中一个经典的问题是判断一棵二叉树B是否是另一棵二叉树A的子结构。本文将深入探讨这个问题&#xff0c;并通过代码示例展示如何解决这一问题。 &#x1f3e0;个人主页&#xff1a;尘觉主页 文…

解决图片导入Excel后变成横向问题

最近有同事遇到图片打开的时候是竖向的&#xff0c;导入Excel后就变成横向了 我在网上搜了一下&#xff0c;没找到直接的答案 我猜大概是用了某些软件做处理&#xff08;例如压缩分辨率&#xff09;但是没处理干净 后来经过多次尝试&#xff0c;发现只要用windows自带的画图软件…

超容易出成果的方向:多模态医学图像处理!

哈喽朋友们&#xff0c;今天给大家推荐一个比较容易出成果的方向&#xff1a;多模态医学图像处理。 众所周知&#xff0c;多模态如今火的一塌糊涂&#xff0c;早就成了很多应用科学与AI结合的重要赛道&#xff0c;特别是在医学图像处理领域。 由此提出的多模态医学图像处理融合…

换代危机,极氪不得不闯的一关

文&#xff5c;刘俊宏 编&#xff5c;王一粟 “今年&#xff0c;不容我们有任何犯错的机会&#xff0c;如果犯错&#xff0c;一定会全盘皆输。” 面临智能化愈发重要的汽车市场&#xff0c;极氪智能科技CEO安聪慧曾在今年初提醒着极氪汽车&#xff08;下简称极氪&#xff09…

开发团队学会应对突发的技术故障和危机

文章目录 一、前言二、应对方法2.1 建立应急响应计划2.2 实时监控与预警2.3 快速定位问题2.4 沟通和协调2.5 调整资源2.6 快速评估影响2.7 利用风险管理工具2.8 备份与恢复策略2.9 客户沟通2.10 事后总结与改进2.11 总结和反思 三、总结 一、前言 8月19日下午&#xff0c;网易…

【前端面试】call、apply 、bind、箭头函数

函数除了传参,还有一个调用上下文this,使用call、apply 、bind可以改变函数的this 在实际开发中,选择使用 call、apply 还是 bind 取决于你的具体需求和场景。以下是一些使用这些函数的常见情况: 1. 使用 call 的情况: 当你需要调用一个函数,并且需要明确指定 this 的上下…

组件提前渲染

问题&#xff1a; 组件正常引入并使用的过程中&#xff0c;出现组件第一次渲染不显示&#xff0c;只有再次刷新页面才显示的问题 <el-table-column label"图纸规定" align"center" prop"tzgd" v-if"mbform.zbzd.tzgd" width"…