【算法基础】选择排序算法 - JAVA

一、算法基础

1.1 什么是选择排序

选择排序是一种简单直观的排序算法,它的工作原理是:首先在未排序序列中找到最小(或最大)元素,存放到排序序列的起始位置,然后再从剩余未排序元素中继续寻找最小(或最大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。

1.2 选择排序的基本思想

选择排序的核心思想是:

  • 将输入数据分为已排序区域和未排序区域
  • 不断从未排序区域选择最小元素,放入已排序区域的末尾
  • 重复上述过程直到全部排序完成

1.3 时间复杂度

选择排序的时间复杂度分析如下:

  • 最好情况时间复杂度:O(n²)
  • 最坏情况时间复杂度:O(n²)
  • 平均时间复杂度:O(n²)

无论输入数据是否已经部分排序,选择排序始终需要进行 n(n-1)/2 次比较,因此其时间复杂度总是 O(n²)。

1.4 空间复杂度

选择排序是一种原地排序算法,它只需要一个用于交换的临时变量,因此空间复杂度为 O(1)

二、Java实现

2.1 基础实现

public class SelectionSort {public static void selectionSort(int[] arr) {int n = arr.length;// 外层循环控制已排序区域的边界for (int i = 0; i < n - 1; i++) {// 找出未排序区域中的最小值索引int minIndex = i;for (int j = i + 1; j < n; j++) {if (arr[j] < arr[minIndex]) {minIndex = j;}}// 将找到的最小值与未排序区域的第一个元素交换if (minIndex != i) {int temp = arr[i];arr[i] = arr[minIndex];arr[minIndex] = temp;}}}// 测试代码public static void main(String[] args) {int[] arr = {64, 25, 12, 22, 11};selectionSort(arr);System.out.println("排序后的数组:");for (int i : arr) {System.out.print(i + " ");}}
}

2.2 算法步骤解析

  1. 初始状态:整个数组视为未排序区域
  2. 第一次迭代
    • 在整个数组中找到最小元素
    • 将其与数组第一个元素交换位置
    • 数组第一个元素现在位于正确位置
  3. 第二次迭代
    • 从第二个元素开始,在剩余未排序元素中找到最小值
    • 将其与数组第二个元素交换位置
  4. 重复过程:继续执行,直到所有元素都排序完毕

三、选择排序的特点

3.1 优点

  • 实现简单,易于理解和编码
  • 交换次数少:每次内循环只需要进行一次交换操作,最多进行 n-1 次交换
  • 原地排序:不需要额外的存储空间
  • 稳定性可控:可以实现为稳定排序算法(通过特定实现方式)

3.2 缺点

  • 时间效率低:无论输入如何,时间复杂度始终为 O(n²)
  • 不适合大规模数据:当数据量大时,性能显著下降
  • 不会提前终止:即使数组已经排序,算法仍会执行完所有步骤

四、算法优化方案

4.1 双向选择排序

双向选择排序在每次迭代中同时查找最小值和最大值,减少了循环次数:

public static void bidirectionalSelectionSort(int[] arr) {int left = 0;int right = arr.length - 1;while (left < right) {int minIndex = left;int maxIndex = left;// 找出最小值和最大值for (int i = left + 1; i <= right; i++) {if (arr[i] < arr[minIndex]) {minIndex = i;}if (arr[i] > arr[maxIndex]) {maxIndex = i;}}// 将最小值放到左边if (minIndex != left) {int temp = arr[left];arr[left] = arr[minIndex];arr[minIndex] = temp;// 如果最大值是left,那么交换后最大值位置变为minIndexif (maxIndex == left) {maxIndex = minIndex;}}// 将最大值放到右边if (maxIndex != right) {int temp = arr[right];arr[right] = arr[maxIndex];arr[maxIndex] = temp;}left++;right--;}
}

4.2 使用堆数据结构

可以使用最小堆来优化选择排序:

  1. 构建一个最小堆 O(n)
  2. 依次取出堆顶元素 O(log n)

这种方法实际上就是堆排序,时间复杂度降低到 O(n log n)。

五、实例分析

5.1 示例数组排序过程

以数组 [64, 25, 12, 22, 11] 为例:

  1. 第一次迭代
    • 找到最小值 11(索引 4)
    • 交换11和64:[11, 25, 12, 22, 64]
    • 已排序:[11],未排序:[25, 12, 22, 64]
  2. 第二次迭代
    • 在剩余部分找到最小值 12(索引 2)
    • 交换12和25:[11, 12, 25, 22, 64]
    • 已排序:[11, 12],未排序:[25, 22, 64]
  3. 第三次迭代
    • 在剩余部分找到最小值 22(索引 3)
    • 交换22和25:[11, 12, 22, 25, 64]
    • 已排序:[11, 12, 22],未排序:[25, 64]
  4. 第四次迭代
    • 在剩余部分找到最小值 25(索引 3)
    • 不需要交换(已在正确位置)
    • 已排序:[11, 12, 22, 25],未排序:[64]
  5. 排序完成[11, 12, 22, 25, 64]

5.2 性能分析

对比不同输入规模的性能表现

  • 小规模数据(n ≤ 50):选择排序性能可接受
  • 中等规模数据(50 < n ≤ 1000):性能明显下降
  • 大规模数据(n > 1000):性能严重下降,不推荐使用

六、应用场景

6.1 适用场景

  • 小规模数据排序:当数据量较小时,选择排序简单易实现
  • 对交换操作敏感的场景:选择排序的交换次数最多为 n-1 次
  • 辅助教学:作为排序算法的基础教学示例
  • 内存受限的嵌入式系统:实现简单且空间复杂度低

6.2 不适用场景

  • 大规模数据排序:性能太低,应选择更高效的算法
  • 几乎已排序的数据:选择排序无法利用数据的部分有序性

七、总结

选择排序是一种简单直观的排序算法,核心思想是不断从未排序区域中选择最小元素放入已排序区域

核心要点

  • 时间复杂度始终为 O(n²),无论输入如何
  • 空间复杂度为 O(1),是一种原地排序算法
  • 交换次数较少,最多进行 n-1 次交换
  • 实现简单,代码易于理解和编写
  • 对于大型数据集不推荐使用

选择排序虽然不是最高效的排序算法,但它的简单性和低空间复杂度使其在特定场景下仍有价值。对于编程初学者来说,理解选择排序有助于掌握排序算法的基本概念及其实现方法。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/79202.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LabVIEW异步调用VI介绍

在 LabVIEW 编程环境里&#xff0c;借助结合异步 VI 调用&#xff0c;并使用 “Open VI Reference” 函数上的 “Enable simultaneous calls on reentrant VIs” 选项&#xff08;0x40&#xff09;&#xff0c;达成了对多个 VI 调用执行效率的优化。以下将从多方面详细介绍该 V…

Leetcode刷题 | Day50_图论02_岛屿问题01_dfs两种方法+bfs一种方法

一、学习任务 99. 岛屿数量_深搜dfs代码随想录99. 岛屿数量_广搜bfs100. 岛屿的最大面积101. 孤岛的总面积 第一类DFS&#xff08;主函数中处理第一个节点&#xff0c;DFS处理相连节点&#xff09;&#xff1a; 主函数中先将起始节点标记为已访问DFS函数中不处理起始节点&…

深入理解网络安全中的加密技术

1 引言 在当今数字化的世界中&#xff0c;网络安全已经成为个人隐私保护、企业数据安全乃至国家安全的重要组成部分。随着网络攻击的复杂性和频率不断增加&#xff0c;保护敏感信息不被未授权访问变得尤为关键。加密技术作为保障信息安全的核心手段&#xff0c;通过将信息转换为…

旧版本NotionNext图片失效最小改动解决思路

旧版本NotionNext图片失效最小改动解决思路 契机 好久没写博客了&#xff0c;最近在notion写博客的时候发现用notionNext同步到个人网站时&#xff0c;图片无法预览。猜测是notion加了防盗链措施&#xff0c;去notionNext官方github上寻找解决方案&#xff0c;需要升级到4.8.…

深度学习笔记40_中文文本分类-Pytorch实现

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 | 接辅导、项目定制 一、我的环境 1.语言环境&#xff1a;Python 3.8 2.编译器&#xff1a;Pycharm 3.深度学习环境&#xff1a; torch1.12.1cu113torchvision…

010302-oss_反向代理_负载均衡-web扩展2-基础入门-网络安全

文章目录 1 OSS1.1 什么是 OSS 存储&#xff1f;1.2 OSS 核心功能1.3 OSS 的优势1.4 典型使用场景1.5 如何接入 OSS&#xff1f;1.6 注意事项1.7 cloudreve实战演示1.7.1 配置cloudreve连接阿里云oss1.7.2 常见错误1.7.3 安全测试影响 2 反向代理2.1 正向代理和反向代理2.2 演示…

【 Node.js】 Node.js安装

下载 下载 | Node.js 中文网https://nodejs.cn/download/ 安装 双击安装包 点击Next 勾选使用许可协议&#xff0c;点击Next 选择安装位置 点击Next 点击Next 点击Install 点击Finish 完成安装 添加环境变量 编辑【系统变量】下的变量【Path】添加Node.js的安装路径--如果…

Python基本语法(自定义函数)

自定义函数 Python语言没有子程序&#xff0c;只有自定义函数&#xff0c;目的是方便我们重复使用相同的一 段程序。将常用的代码块定义为一个函数&#xff0c;以后想实现相同的操作时&#xff0c;只要调用函数名就可以了&#xff0c;而不需要重复输入所有的语句。 函数的定义…

OpenGL-ES 学习(11) ---- EGL

目录 EGL 介绍EGL 类型和初始化EGL初始化方法获取 eglDisplay初始化 EGL选择 Config构造 Surface构造 Context开始绘制 EGL Demo EGL 介绍 OpenGL-ES 是一个操作GPU的图像API标准&#xff0c;它通过驱动向 GPU 发送相关图形指令&#xff0c;控制图形渲染管线状态机的运行状态&…

极简5G专网解决方案

极简5G专网解决方案 利用便携式即插即用私有 5G 网络提升您的智能创新。为您的企业提供无缝、安全且可扩展的 5G 解决方案。 提供极简5G专网解决方案 Mantiswave Network Private Limited 提供全面的 5G 专用网络解决方案&#xff0c;以满足您企业的独特需求。我们创新的“…

html:table表格

表格代码示例&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title> </head> <body><!-- 标准表格。 --><table border"5"cellspacing&qu…

tkinter 电子时钟 实现时间日期 可实现透明

以下是一个使用Tkinter模块创建一个简单的电子时钟并显示时间和日期的示例代码&#xff1a; import tkinter as tk import time# 创建主窗口 root tk.Tk() root.overrideredirect(True) # 隐藏标题栏 root.attributes(-alpha, 0.7) # 设置透明度# 显示时间的标签 time_labe…

【报错问题】 macOS 的安全策略(Gatekeeper)阻止了未签名的原生模块(bcrypt_lib.node)加载

这个错误是由于 macOS 的安全策略&#xff08;Gatekeeper&#xff09;阻止了未签名的原生模块&#xff08;bcrypt_lib.node&#xff09;加载 导致的。以下是具体解决方案&#xff1a; 1. 临时允许加载未签名模块&#xff08;推荐先尝试&#xff09; 在终端运行以下命令&#x…

AI实现制作logo的网站添加可选颜色模板

1.效果图 LogoPalette.jsx import React, {useState} from react import HeadingDescription from ./HeadingDescription import Lookup from /app/_data/Lookup import Colors from /app/_data/Colors function LogoPalette({onHandleInputChange}) { const [selectOptio…

云原生后端架构的挑战与应对策略

📝个人主页🌹:慌ZHANG-CSDN博客 🌹🌹期待您的关注 🌹🌹 随着云计算、容器化以及微服务等技术的快速发展,云原生架构已经成为现代软件开发和运维的主流趋势。企业通过构建云原生后端系统,能够实现灵活的资源管理、快速的应用迭代和高效的系统扩展。然而,尽管云原…

【C++】模板为什么要extern?

模板为什么要extern&#xff1f; 在 C 中&#xff0c;多个编译单元使用同一个模板时&#xff0c;是否可以不使用 extern 取决于模板的实例化方式&#xff08;隐式或显式&#xff09;&#xff0c;以及你对编译时间和二进制体积的容忍度。 1. 隐式实例化&#xff1a;可以不用 ex…

中小企业MES系统数据库设计

版本&#xff1a;V1.0 日期&#xff1a;2025年5月2日 一、数据库架构概览 1.1 数据库选型 数据类型数据库类型技术选型用途时序数据&#xff08;传感器读数&#xff09;时序数据库TimescaleDB存储设备实时监控数据结构化业务数据关系型数据库PostgreSQL工单、质量、设备等核心…

VUE篇之树形特殊篇

根节点是level:1, level3及其子节点有关联&#xff0c;但是和level2和他下面的子节点没有关联 思路&#xff1a;采用守护风琴效果&#xff0c;遍历出level1和level2级节点&#xff0c;后面level3的节点&#xff0c;采用树形结构进行关联 <template><div :class"…

洛圣电玩系列部署实录:一次自己从头跑通的搭建过程

写这篇文章不是为了“教大家怎么一步步安装”&#xff0c;而是想把我自己完整跑通洛圣电玩整个平台的经历复盘下来。因为哪怕你找到了所谓的全套源码资源&#xff0c;如果没人告诉你这些资源之间是怎么连起来的&#xff0c;你依旧是一脸懵逼。 我拿到的是什么版本&#xff1f; …

腾讯云web服务器配置步骤是什么?web服务器有什么用途?

腾讯云web服务器配置步骤是什么?web服务器有什么用途&#xff1f; Web服务器配置步骤&#xff08;以常见环境为例&#xff09; 1. 安装Web服务器软件 Linux系统&#xff08;如Ubuntu&#xff09; Apache: sudo apt update sudo apt install apache2 Nginx: sudo apt install…