【唐叔学算法】第18天:解密选择排序的双重魅力-直接选择排序与堆排序的Java实现及性能剖析

news/2024/12/23 16:56:27/
引言

在数据排序的世界里,选择排序是一类简单而直观的算法,它通过不断选取未排序部分中的最小(或最大)元素来逐步构建有序序列。今天,我们将深入探讨两种基于选择思想的排序方法——直接选择排序和堆排序,并提供它们的Java实现代码。此外,我们还会分析这两种排序算法的时间复杂度和空间复杂度,帮助你理解其背后的运作机制。

直接选择排序(Selection Sort)
算法描述

直接选择排序是一种最基础的选择排序形式。它的基本思想是每次从未排序的元素中选出最小的一个元素,然后将其与未排序部分的第一个元素交换位置。如此反复,直到所有元素都被排好序为止。

时间复杂度
  • 最佳、平均和最差情况均为 O(n²),其中 n 是待排序数组的长度。
空间复杂度
  • 因为只需要常数级别的额外空间,所以空间复杂度为 O(1)。
Java实现
public class SelectionSort {public static void sort(int[] arr) {for (int i = 0; i < arr.length - 1; i++) {int minIndex = i;for (int j = i + 1; j < arr.length; j++) {if (arr[j] < arr[minIndex]) {minIndex = j;}}// 交换找到的最小元素和当前元素int temp = arr[minIndex];arr[minIndex] = arr[i];arr[i] = temp;}}public static void main(String[] args) {int[] data = {64, 25, 12, 22, 11};sort(data);System.out.println("Sorted array: " + Arrays.toString(data));}
}
堆排序(Heap Sort)
算法描述

堆排序利用了二叉堆的数据结构特性。首先将待排序的数组构建成一个大根堆(对于升序排列),接着依次取出堆顶的最大元素放到数组末尾,再调整剩余元素重新构成大根堆,重复此过程直至所有元素都被排序。

时间复杂度
  • 构建堆的时间复杂度为 O(n),而每一次调整堆的操作时间复杂度为 O(log n),因此总的时间复杂度为 O(n log n)。
空间复杂度
  • 和直接选择排序一样,堆排序的空间复杂度也是 O(1),因为它是在原地进行排序。
Java实现
public class HeapSort {public static void sort(int[] arr) {int n = arr.length;// 构建大根堆for (int i = n / 2 - 1; i >= 0; i--)heapify(arr, n, i);// 一个个从堆中提取元素for (int i = n - 1; i >= 0; i--) {// 移动当前根到末尾int temp = arr[0];arr[0] = arr[i];arr[i] = temp;// 调用heapify函数在减少的堆上heapify(arr, i, 0);}}// 对大小为n的以i为根节点的堆进行heapify操作private static void heapify(int[] arr, int n, int i) {int largest = i; // 初始化最大的为根int left = 2 * i + 1; // 左子节点int right = 2 * i + 2; // 右子节点// 如果左子节点大于根if (left < n && arr[left] > arr[largest])largest = left;// 如果右子节点大于最大的if (right < n && arr[right] > arr[largest])largest = right;// 如果最大的不是根if (largest != i) {int swap = arr[i];arr[i] = arr[largest];arr[largest] = swap;// 递归地heapify受影响的子树heapify(arr, n, largest);}}public static void main(String[] args) {int[] data = {12, 11, 13, 5, 6, 7};sort(data);System.out.println("Sorted array is: " + Arrays.toString(data));}
}
结语

通过上述讲解,我们可以看出直接选择排序和堆排序虽然都属于选择排序,但它们有着显著的不同之处。前者更易于理解和实现,但在处理大数据量时效率较低;后者则具有更好的性能表现,特别是在需要频繁访问最大或最小值的应用场景下。希望这篇文章能为你揭开选择排序的神秘面纱,并为你的编程之旅增添一份力量。


http://www.ppmy.cn/news/1557518.html

相关文章

matlab Patten的使用(重要)(Matlab处理字符串一)

原文连接&#xff1a;https://www.mathworks.com/help/releases/R2022b/matlab/ref/pattern.html?browserF1help 能使用的搜索函数&#xff1a; contains确定字符串中是否有模式matches确定模式是否与字符串匹配count计算字符串中模式的出现次数endsWith确定字符串是否以模式…

vue中高德地图api的使用

在我们使用高德地图的时候&#xff0c;官方给我们推荐了很多案例&#xff0c;但是这些案例都是使用原生方法接入&#xff0c;并没有提供 vue 或者 react 的demo&#xff0c;vue2的接入网上也很多人都有写过&#xff0c;今天我们就来看看 vue3 如何使用常用的高德地图api。前置工…

量化交易——RSI策略(vectorbt实现)

本文为通过vectorbt&#xff08;以下简称vbt&#xff09;实现量化交易系列第一篇文章&#xff0c;通过使用vbt实现RSI策略从而熟悉其代码框架。 关于本文所使用数据的说明 由于vbt官方文档提供的入门案例使用的数据是通过其内置的yfinance包获取&#xff0c;在国内无法直接访…

电商数据采集电商,行业数据分析,平台数据获取|稳定的API接口数据

电商数据采集可以通过多种方式完成&#xff0c;其中包括人工采集、使用电商平台提供的API接口、以及利用爬虫技术等自动化工具。以下是一些常用的电商数据采集方法&#xff1a; 人工采集&#xff1a;人工采集主要是通过基本的“复制粘贴”的方式在电商平台上进行数据的收集&am…

我的个人博客正式上线了!

我的个人博客终于上线啦点此访问 经过一番折腾&#xff0c;我的个人博客终于上线啦&#xff01;这是一个属于我自己的小天地&#xff0c;可以用来记录生活点滴、技术分享以及一些随想。 在这里&#xff0c;我想分享一下搭建博客的整个过程和心得体会。 为什么要搭建博客&…

速通Python 第四节——函数

一、函数 编程中的函数和数学中的函数有一定的相似之处. 数学上的函数, 比如 y sin x , x 取不同的值, y 就会得到不同的结果. 编程中的函数, 是一段 可以被重复使用的代码片段 代码示例 : 求一段范围的数的和 , 不使用函数 # 1. 求 1 - 100 的和 sum 0 for i in range(1, …

【2025最新计算机毕业设计】新型吃住玩一体化旅游管理系统【提供源码+答辩PPT+文档+项目部署】

作者简介&#xff1a;✌CSDN新星计划导师、Java领域优质创作者、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流。✌ 主要内容&#xff1a;&#x1f31f;Java项目、Python项目、前端项目、PHP、ASP.NET、人工智能…

【Leetcode 每日一题】1387. 将整数按权重排序

问题背景 我们将整数 x x x 的 权重 定义为按照下述规则将 x x x 变成 1 1 1 所需要的步数&#xff1a; 如果 x x x 是偶数&#xff0c;那么 x x / 2 x x / 2 xx/2。如果 x x x 是奇数&#xff0c;那么 x 3 x 1 x 3 \times x 1 x3x1。 比方说&#xff0c; x …