当前位置: 首页 > news >正文

排序算法之选择排序

选择排序的思想是每次从未排序的部分中选择最小的元素,然后将其放在已经排序部分的末尾。

  1. 遍历数组,从第一个元素开始,将其视为当前最小元素。
  2. 在未排序的部分中,找到最小的元素,并记录其索引。
  3. 将最小的元素与当前位置的元素交换位置
  4. 重复步骤2和步骤3,直到遍历完整个数组

比如有一个数组arr=[8,2,4,5,1,6,0,1]
我们要进行选择排序,先选择最小的,然后选择第二小的,然后是选择第三小的,依次类推。
选择排序是一种是原地排序算法

选择排序算法是不稳定的排序算法

执行流程

  1. 从序列中找出最大的哪个元素,然后于最末尾的元素交换位置
  2. 执行完一轮之后,最后的哪个元素就是最大的元素
  3. 忽略掉上一轮中找到的最大元素,重复执行步骤1
package com.lut.sort;import java.util.Arrays;public class SelectionSort {public static void main(String[] args) {int[] arr = {8,2,4,5,1,6,0,1};selectionSort(arr);System.out.println(Arrays.toString(arr));}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; j < n; j++) {if(arr[j] < arr[minIndex]){minIndex = j;}}int temp = arr[minIndex];arr[minIndex] = arr[i];arr[i] = temp;}}
}

http://www.mrgr.cn/news/42830.html

相关文章:

  • 分布式学习02-CAP理论
  • Linux进程控制(2)(进程程序替换1)
  • 【3D目标检测】激光雷达和相机联合标定(一)——ROS同步解包
  • python学习记录6
  • 堆排序算法的原理与应用
  • 基于Keras的U-Net模型在图像分割与计数中的应用
  • 企业级数据备份一般都是怎么做的?来唠唠嗑
  • pytest(三)——参数化@pytest.mark.parametrize
  • node_exporter使用textfile collector收集业务数据
  • PostgreSQL 创建账号与数据库:从连接到权限配置的完整指南
  • 绝对值得收藏!分享7款ai写作论文免费一键生成网站
  • 基于深度学习的视频生成
  • 算法笔记(九)——栈
  • 泛型编程--模板【C++提升】(特化、类属、参数包的展开、static、模板机制、重载......你想知道的全都有)
  • 10月4日刷题记录
  • C题(八)一个正整数的逆序打印(用循环结构实现)
  • CTK框架(十一):使用的常见问题
  • Pytorch最最适合研究生的入门教程,Q3 开始训练
  • 最新版本SkyWalking【10.1.0】部署
  • 计数相关的题 Python 力扣