排序算法之选择排序

news2024/12/24 21:53:58

今天来给大家介绍一下排序算法之选择排序

选择排序:(Selection sort)是一种简单直观的排序算法,也是一种不稳定的排序方法。

选择排序的原理:

一组无序待排数组,做升序排序,我们先假定第一个位置上的数据就是最小的,我们用一个参数记录这个最小的数,然后依次把后面的每个位置的数据和这个最小的比较,如果比这个数小就替换两个位置数据,等到第一轮比较完成就能确定最小的数据排在第一位了,然后第二轮从第二个位置开始,相同的方式比较,每次都能找到本轮最小的值,直至全部待排元素个数为0的时候,数组就排好顺序了。

选择排序流程图

我们来进行详细解析看看

首先我们给个无序数组[4,6,15,9,12,3,32]进行升序排序,因为需要确定每个数组的长度,所以需要比较数组长度-1轮,当前面的元素都排好了之后,那么数组最后一个元素自然就确定了位置。

我们定义两个值,minIndex,minNum用来分别表示每一轮的找到的最小值的下标和值,后面未排序的值都和minNum比较,从而找出每一轮的最小值。

  • 第一轮我们以下标为1的第一位作为标志位(也就是把第一个值当做最小值),那么此时minIndex=0,minNum=4,经过和 minNum 比较发现后面只有3比4小,那么3和4交换位置,minIndex=5,minNum=3,把4换到下标为5的位置,如下图所示:

第一轮我们得到的结果是[3,6,15,9,12,4,32],本轮最小数是:3,所以3放到本轮标志位,也就是第一位

  • 第二轮:拿到第一轮排序的值作为初始值[3,6,15,9,12,4,32],同第一轮一样,此时6作为标志位minNum=6,minNum和其他比较,只有4比6小,需要交换位置,如下图所示

    第二轮排序结果[3,4,15,9,12,6,32],本轮最小数是:4

  • 第三轮:初始值[3,4,15,9,12,6,32],这次标志位15,minNum=15,minIndex=2,minNum先比和9比较,发现9比15小,minNum=9,minIndex=3,然后minNum和12比较,不需要替换minNum,再和6比较,minNum=6,minIndex=5,后面再比较已经没有比6小了,那么本轮就是初始标志位15和下标为5,值为6的数据换位置。

    第三轮排序结果[3,4,6,9,12,15,32],本轮最小数是:6

  • 第四、五、六轮:初始值[3,4,6,9,12,15,32],经过前面的比较我们可以看到数组已经排序完成,但是程序并不知道,会继续比较下去,把下标为4、5、6位置都作为标志位比较一次,发现都不需要变动位置,那么最终执行完成之后就能排序完成

    第四、五、六轮排序结果[3,4,6,9,12,15,32]

到这,我们已经清楚了每个步骤做了什么,那么接下来上代码验证一下:

Java代码实现

 public class selectionSort {
     public static void main(String[] args){
          int[] arr = new int[]{4,6,15,9,12,3,32};
         for(int i=0;i<arr.length-1;i++){//每次循环都会找出最小的数
             //记录最小数的下标
             int minIndex = i;
             //记录最小数
             int minNum = arr[i];
             //每次循环都会找出最小的数
             for(int j=i+1;j<arr.length;j++){
                 if(arr[j]<minNum){//如果当前数比最小数小,则更新最小数
                     minNum = arr[j];//更新最小数
                     minIndex = j;//更新最小数的下标
                 }
             }
             //将最开始假定的小的数移动到真实最小的位置
             arr[minIndex]=arr[i];
             arr[i]=minNum;//将标志位放到最小数原来所在的位置
             
             //打印结果,方便查看
             System.out.print("第"+(i+1)+"轮[");
             for(int a=0;a<arr.length;a++){
                 System.out.print(arr[a]+"\t");
             }
             System.out.println ("],本轮最小数是:"+minNum);
         }
         System.out.print("最终结果[");
         for(int i=0;i<arr.length;i++){
             System.out.print(arr[i]+"\t");
         }
         System.out.println("]");
     }
 }

输出结果

  第1轮[3 6 15 9 12 4 32 ],本轮最小数是:3
  第2轮[3 4 15 9 12 6 32 ],本轮最小数是:4
  第3轮[3 4 6 9 12 15 32 ],本轮最小数是:6
  第4轮[3 4 6 9 12 15 32 ],本轮最小数是:9
  第5轮[3 4 6 9 12 15 32 ],本轮最小数是:12
  第6轮[3 4 6 9 12 15 32 ],本轮最小数是:15
  最终结果[3 4 6 9 12 15 32 ]

时间复杂度

我们通过上面的细节拆分发现,无论是否是已经排好的还是没排好的情况,我们都需要每个数字都比较到,那么就出现N个元素的数组,第一轮是n次比较,第二轮是从第二个位置开始,那么就是n-1,第三轮就是n-2次... 最后是1,那么就出现了n+(n-1)+(n-2)+(n-3)...1,这是一个等差数列,求和为一个二次型多项式,因为等差数列求和会出现二次型;我们取最高阶就是n^2,所以时间复杂度就是O(n^2),而且最好和最坏的情况时间复杂度都是O(n^2)

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

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

相关文章

【生成模型】Diffusion Models:概率扩散模型

---前言一、Diffusion Model 基本介绍二、生成模型对比三、直观理解Diffusion model四、形式化解析Diffusion model五、详解 Diffusion Model&#xff08;数学推导&#xff09;1.前向过程(扩散过程)2.逆扩散过程3.逆扩散条件概率推导4.训练损失六、训练、测试伪代码1. 训练2.测…

鲲鹏devkit编译调试工具——《sudoku》作业解析

《sudoku》作业解析 本次实验以sudoku项目为例介绍鲲鹏编译调试插件的基本使用方法 本次实验的步骤主要为 获取源码安装鲲鹏编译调试插件服务器配置进行代码同步配置配置测试任务进行编译调试 接下来我们先获取本次实验所需要的源码 获取源码 sudoku项目已经上传到github使…

stata外部命令大全(包含面板门槛、系统GMM、空间计量、Pvar、中介效应等)

1、数据来源&#xff1a;自主整理 2、时间跨度&#xff1a;无 3、区域范围&#xff1a;无 4、指标说明&#xff1a; 该些外部命令包含面板门槛、系统GMM、空间计量、pvar、中介效应等涵盖全部 以下是部分命令截图&#xff1a; 空间计量&#xff1a; 系统GMM&#xff08;动…

Allure使用手册

一. 简介 Allure是一款支持多语言的测试结果可视化软件&#xff0c;支持Java、Python&#xff0c;搭配Junit、pytest等测试框架食用更香。本文主要讲解搭配Junit4。 二. 下载、安装部署 2.1 下载 百度搜索Allure2&#xff01;&#xff01;&#xff01; 敲重点&#xff1a;…

基于Qlearning强化学习的倒立摆控制系统matlab仿真

目录 1.算法描述 2.仿真效果预览 3.MATLAB部分代码预览 4.完整MATLAB程序 1.算法描述 强化学习通常包括两个实体agent和environment。两个实体的交互如下&#xff0c;在environment的statestst下&#xff0c;agent采取actionatat进而得到rewardrtrt 并进入statest1st1。Q-l…

【头歌实验】五、Python循环结构

文章目录>>>第1关&#xff1a;达依尔的麦子数任务描述案例分析相关知识for循环测试说明参考答案>>>第2关&#xff1a;四级单词查询任务描述案例分析相关知识如何处理文件文件打开文件循环文件关闭遍历文件测试说明第3关&#xff1a;出租车车费计算任务描述案…

Monaco Editor教程(十八):使用api来完成某些键盘操作,格式化,查找,显示右侧菜单等。

背景 在一般的Web IDE中&#xff0c;我们需要将经常用到的一些操作放到顶部操作栏里&#xff0c;类似语雀的文档编辑。 代码编辑器&#xff0c;一般也会放一些查找&#xff0c;格式化&#xff0c;撤销&#xff0c;恢复。有些人喜欢用快捷键来进行这些操作&#xff0c;但由于mo…

Packet Tracer - 配置 OSPF 高级功能

地址分配表 设备 接口 IPv4 地址 子网掩码 默认网关 R1 G0/0 172.16.1.1 255.255.255.0 不适用 S0/0/0 172.16.3.1 255.255.255.252 不适用 S0/0/1 192.168.10.5 255.255.255.252 不适用 R2 G0/0 172.16.2.1 255.255.255.0 不适用 S0/0/0 172.16.3.2 …

论文笔记: 全波形反演的无监督学习: 将 CNN 与偏微分方程做成一个环

摘要: 分享对论文的理解, 原文见 Peng Jin, Xitong Zhang, Yinpeng Chen, Sharon Xiaolei Huang, Zicheng Liu, Youzuo Lin, Unsupervised learning of full-waveform inversion: connecting CNN and partial differential equation in a loop. 论文发表于计算机方面的顶会 ICL…

(续)SSM整合之SSM整合笔记(Spring整合MyBatis)(P179-188)

一 准备工作 1 新建模块ssm com.atguigu.ssm 2 导入依赖 <packaging>war</packaging><properties><spring.version>5.3.1</spring.version> </properties><dependencies><dependency><groupId>org.springframewo…

Linux:进程(二)

文章目录前言一、环境变量1.概念2.常见环境变量3.一个疑问4.通过系统调用获取或设置环境变量二、地址空间1.引入2.分页&进程地址空间1.页表2.写时拷贝3.为什么要有地址空间总结前言 今天我们继续学习进程相关知识。 一、环境变量 1.概念 环境变量(environment variables)…

从理解路由到实现一套Router(路由)

平时在Vue项目中经常用到路由&#xff0c;但是也仅仅处于会用的层面&#xff0c;很多基础知识并不是真正的理解。于是就趁着十一”小长假“查阅了很多资料&#xff0c;总结下路由相关的知识&#xff0c;查缺不漏&#xff0c;加深自己对路由的理解。 路由 在 Web 开发过程中&a…

Redis中最简单的存储类型:String

String类型&#xff0c;也就是字符串类型&#xff0c;是Redis中最简单的存储类型。 其value是字符串&#xff0c;不过根据字符串的格式不同&#xff0c;又可以分为3类&#xff1a; string&#xff1a;普通字符串 int&#xff1a;整数类型&#xff0c;可以做自增、自减操作 f…

CentOS虚拟机装完了,不能粘贴window命令行?不能上网?

文章目录前言关于CentOS安装版本如何实现粘贴命令行CentOS命令行模式下如何联网&#xff1f;结尾前言 最近想系统学习Linux环境下系统运维&#xff0c;所以安装了CentOS 7虚拟机&#xff0c;但是个人笔记本上和工作电脑上无意中下载了不同镜像进行安装&#xff0c;有一台机器无…

Nerf三维重建Pytorch使用Pycharm运行0基础教程

Nerf三维重建Pytorch使用Pycharm运行0基础教程 你好&#xff01; 这里是“出门吃三碗饭”本人&#xff0c;本文章接下来将介绍如何从0运行2020会议Nerf的Pytorch版本&#xff0c;让你自己动手渲染第一个三维模型。视频解说可以关注B站&#xff0c;搜索 出门吃三碗饭 &#xff…

Improving Inductive Link Prediction Using Hyper-Relational Facts

摘要 多年来,知识图(KGs)上的链接预测一直是一个纯粹的转换任务,不允许对看不见的实体进行推理。最近,越来越多的努力被投入到探索半和全归纳场景,使推理能够对不可见的和新兴的实体。然而,所有这些方法都只考虑基于三元组的kg,而它们更丰富的对应,超关系KG(如Wikidata…

OWASP ZAP mac chrome代理配置取消URL强制Https【已解决】

1.OWASP ZAP OWASP Zed攻击代理&#xff08;ZAP&#xff09;是世界上最受欢迎的免费安全审计工具之一&#xff0c;由数百名国际志愿者积极维护。它可以帮助你在开发和测试应用程序时自动查找Web应用程序中的安全漏洞。 也可以说ZAP是一个中间人代理。它能够获取你对Web应用程…

2022亚太赛题浅评

2022年亚太今日已经正式开赛&#xff0c;为了帮助大家更好的选题建模&#xff0c;这里首先对ABC三道题目进行浅要评析&#xff0c;以方便大家更好的择题。同时相关资料也会后续进行补充。预计明日公布各题统计选题人数以及较为完善的资料。今天作为第一天重要的是择好题&#x…

XCTF1-web easyupload

easyupload 题目描述 一名合格的黑客眼中&#xff0c;所有的上传点都是开发者留下的后门 进入场景 是个文件上传的页面&#xff0c;测试上传的文件类型&#xff0c;发现是图片上传点 上传正常图片&#xff0c;会回显文件上传的路径 尝试推测文件上传检测点 测试后缀名php、…

Flutter高仿微信-第30篇-单聊-文本

Flutter高仿微信系列共59篇&#xff0c;从Flutter客户端、Kotlin客户端、Web服务器、数据库表结构、Xmpp即时通讯服务器、视频通话服务器、腾讯云服务器全面讲解。 详情请查看 效果图&#xff1a; 详情请参考Flutter高仿微信-第29篇-单聊 &#xff0c; 这里只是提取文本实现的部…