选择排序算法流程图_常用排序算法之选择排序

前两天给大家分享了冒泡排序和插入排序(没关注的同学,可以关注后查看历史消息),今天继续给大家分享另一种常用的排序算法--选择排序

选择排序

选择排序和插入排序很相似,也区分已排序区间和未排序区间,选择排序是每次从未排序区间找到最小的元素放到已排序区间的末尾。

如下图:

23171245a61fda880e7b1e819348f8c6.png

代码示例

go示例:

func SelectionSort(nums []int, n int) {    if n <= 1 {        return    }    for i := 0; i < n; i++ {        min := i        for j := i + 1; j < n; j++ {            if nums[j] < nums[min] {                min = j            }        }        if min != i {            nums[i], nums[min] = nums[min], nums[i]        }    }}

PHP示例:

function SelectionSort($nums) {      if(count($nums) <= 1 ){            return $nums;      }      for ($i = 0; $i < count($nums);$i++) {            $min = $i;            for ($j = $i + 1; $j < count($nums); $j++) {                  if ($nums[$min] > $nums[$j]) {                        $min = $j;                  }            }            if ($min != $i) {                  $temp = $nums[$i];                  $nums[$i] = $nums[$min];                  $nums[$min] = $temp;            }      }      return $nums;}

JS示例:

const selectionSort = (arr) => {      if (arr.length <= 1) return      for (let i = 0; i < arr.length - 1; i++) {            let minIndex = i            for (let j = i + 1; j < arr.length; j++) {                  if (arr[j] < arr[minIndex]) {                        minIndex = j                  }            }            const temp = arr[i]            arr[i] = arr[minIndex]            arr[minIndex] = temp      }      console.log(arr)}

性能分析

最后我们看下插入排序的性能和稳定性:

  1. 时间复杂度:嵌套了两个循环,O(n2)
  2. 空间复杂度:不需要额外的存储空间,是原地排序算法
  3. 算法稳定性:每次都要找未排序区间的最小值并和前面的元素交换位置,涉及到位置交换,是不稳定的排序算法

介绍完了三种排序算法,时间复杂度都是O(n2),也都是原地排序,选择排序是不稳定的排序算法。插入排序和冒泡排序相比,插入排序需要一条语句,冒泡排序需要三个赋值语句,所以插入排序要优于冒泡排序。

但是在数据量大的时候这三个排序算法都不是很理想,接下来我会再分享两种时间复杂度为O(nlogn)的排序算法。

最后,关注下呗~

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

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

相关文章

pygame小游戏代码_Py之pygame:有趣好玩——利用pygame库实现一个移动底座弹球的小游戏...

Py之pygame&#xff1a;有趣好玩——利用pygame库实现一个移动底座弹球的小游戏目录输出结果实现代码输出结果​实现代码# -*- coding: utf-8 -*-#Py之pygame&#xff1a;有趣好玩——利用pygame库实现一个移动底座弹球的小游戏import pygame as pg from pygame.locals import …

大白菜pe解锁bitlocker_微PE工具箱 v2.1 官方版,最好用的 Win10PE 系统

微PE工具箱 v2.1 – 最好用的WinPE装机维护工具&#xff01;WinPE工具箱&#xff0c;装机维护最得力的助手&#xff0c;最后救命稻草。化繁为简&#xff0c;小材大用&#xff0c;一键安装&#xff0c;极速启动。微PE工具箱&#xff0c;最好用的PE工具箱&#xff0c;没有之一。无…

java8用什么tomcat_Tomcat8+JDK8安装与配置

一&#xff0c;系统配置1.操作系统&#xff1a;win10 64位2.tomcat版本&#xff1a;Tomcat8 64位3.Java版本&#xff1a;JDK8 64位二&#xff0c;软件下载下载到本地后直接打开安装&#xff0c;修改存储目录&#xff0c;如图&#xff1a;2.2 Tomcat8下载&#xff0c;官网地址&…

谷歌离开游览器不触发_谷歌游览器

谷歌浏览器不错&#xff0c;可保存不同的账户&#xff0c;互相不干扰。有2个账号&#xff0c;工作账号和个人账号&#xff0c;泾渭分明&#xff0c;不会打架&#xff0c;管理账号。总经理管理公司人员&#xff0c;厂长管理工人&#xff0c;业务员要管理自己账号&#xff0c;管理…

vue保存图片到手机相册_手机照片误删了怎么找回?这三个方法轻松搞定,亲测有效...

手机照片误删了怎么找回&#xff1f;很多人在使用手机拍照时&#xff0c;都会出现拍好的照片不小心点击了删除等情况&#xff0c;比如去某个地方游玩&#xff0c;或者看到了某个特别的场景拍下来的时候不小心删除了&#xff0c;那就非常可惜了&#xff0c;那么如何找回手机中误…

vue if判断_VUE学习记录2

v-if、v-eles、v-else-if​ v-if用于条件判断&#xff0c;判断Dom元素是否显示。<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scal…

利用melendy插入参考文献_四苯基卟啉在改性磷酸锆层间的插入及荧光增强

一、摘要近年来&#xff0c;出于节约一次性能源的考虑&#xff0c;人们已经加大对太阳能等天然资源的利用&#xff0e;致力于模拟天然光合作用的研究&#xff0c;而光合作用中的捕光复合物又称为光子天线。光子天线中往往存在一种或几种猝灭剂&#xff0c;猝灭剂吸收光子后产生…

百度链接解析_【集合】百度分享链接解析的方法总结

请大家在使用所有方法之前请先查看菜单栏中的用前必看01在别人分享的链接前面加 http://pan.naifei.cc/? 然后放入浏览器就可以解析了。比如: http://pan.naifei.cc/?链接:https://pan.baidu.com/s/XXX 提取码:1234 复制这段内容后打开百度网盘手机App&#xff0c;操作更方…

table表头固定4种方法_在常见的3种工资条场景中,教你4种批量打印工资条的方法...

私信回复关键词【福利】~获取丰富办公资源&#xff0c;助你高效办公早下班&#xff01;打印工资条估计是财务老师的痛&#xff0c;要把一行行的数据&#xff0c;变成一条条的工资条。数据很多&#xff0c;表头很复杂。一个个复制粘贴&#xff1f;那是不可能的&#xff01;那怎么…

hbase java api最新版本_HBase基本命令与新版本Java API

简介有关HBase的安装可以参考hbase安装我们可以通过hbase shell和hbase数据库进行交互&#xff0c;也可以通过Java-api和hbase数据库交互&#xff0c;这里我们使用的是hbase-client。主要是介绍2.0重大重构之后的api的基本使用。命名空间#列出所有命名空间list_namespace#新建命…

java导致native非法指令,Java代码引起的NATIVE野指针问题(上)

朴英敏&#xff0c;小米MIUI部门。从事嵌入式开发和调试工作8年多&#xff0c;擅长逆向分析方法&#xff0c;主要负责解决安卓系统稳定性问题。上周音乐组同事反馈了一个必现Native Crash问题&#xff0c;tombstone如下&#xff1a; pid: 5028, tid: 5028, name: com.miui.play…

axure怎么做5秒倒计时_罗胖60秒:怎么做一个课程?

今天是罗胖陪伴你的第 2714 天1. 我们在研发课程的时候&#xff0c;有一个很关键的方法&#xff0c;我们内部称之为叫“不是而是”大法。2. 什么意思呢&#xff1f;就是如果你只告诉别人它是什么&#xff0c;那等于啥都没说。比如&#xff0c;我告诉你要经营好一家小店&#xf…

树莓派跑php,在树莓派4上部署nginx+php

本试验是基于树莓派的 buster 版本。一、安装 nginxapt install nginx -y完成安装之后&#xff0c;可以使用 dpkg -l | grep nginx 找到相关的安装包&#xff1a;通过分析 /var/lib/dpkg/status 可以得到 nginx 安装包的依赖关系&#xff1a;nginx --> nginx-full --> li…

php 如何生成微信小程序,微信小程序一键生成平台系统/一键生成小程序开源小程序PHP|ThinkPHP平台源码下载...

源码名称&#xff1a;微信小程序一键生成平台系统/一键生成小程序开源小程序PHP|ThinkPHP平台源码下载购买须知&#xff1a;(请仔细阅读了解)【1】源码一律经测试无误。【2】不提供任何修改和编辑服务&#xff0c;不包安装调试&#xff0c;假如你什么都不懂的请不要拍。【3】假…

java .item,javabb-javaitem-cloud

JavaItem-Cloud项目介绍JavaItem-Cloud是一个新开发的微服务架构平台&#xff0c;基于最新流行的技术SpringBoot、SpringCloud & SpringCloud Alibaba、Vue、Vuex、ElementUI。系统特性后端使用当前流行技术&#xff0c;SpringBoot、SpringCloud、SpringCloud Alibaba、Myb…

软件使用手册模板_我的印象笔记使用手册(精简说明)

在之前的一文中&#xff0c;我已经详细写过我的印象笔记使用的方法了&#xff0c;这次呢&#xff0c;再做一个更新的使用情况和更清楚明了和精简的说明。不居竹&#xff1a;我的印象笔记使用手册​zhuanlan.zhihu.com文章目录&#xff1a;1、知识管理收集知识整理知识输出知识2…

通信之道从微积分到5gpdf_保送清华成博士,华为12年搞通信,他为何如此看待 5G ?| 人物志...

作者 | 伍杏玲 胡巍巍出品 | CSDN(ID&#xff1a;CSDNnews)一位通信专家&#xff0c;清华读了博士&#xff0c;北大从事博士后研究工作&#xff0c;但却只有12年工作经历&#xff1f;明明家里几套房&#xff0c;却热爱骑车出行&#xff1f;他是&#xff1f;他是国内小有名气的通…

mysql封装 javabean,利用Java针对MySql封装的jdbc框架类JdbcUtils完整实现(包含增删改查、JavaBean反射原理,附源码)...

最近看老罗的视频&#xff0c;跟着完成了利用Java操作MySql数据库的一个框架类JdbcUtils.java,完成对数据库的增删改查。其中查询这块&#xff0c;包括普通的查询和利用反射完成的查询&#xff0c;主要包括以下几个函数接口:1、public Connection getConnection() 获得数据库的…

云计算的发展趋势_2020年的云计算发展趋势预测

点击上方“蓝色字体”&#xff0c;选择 “设为星标”关键讯息&#xff0c;D1时间送达&#xff01;SnapLogic公司首席技术官Craig Stewart表示&#xff0c;企业需要为不同的目的使用多个云平台&#xff0c;这将意味着多云应用的普及率将上升。在新的一年即将到来之际&#xff0c…

php x86什么意思,win10x86是什么意思

小编之前也是不知道x86是什么意思的&#xff0c;后来我的一个朋友给我好好的解释了一通我才明白。所以既然小编花了点时间才那个问题弄明白的&#xff0c;那接下来小编就来好好给你们说说x86是什么意思。小编最近发现有小伙伴在问x86是什么意思之类的问题&#xff0c;于是小编借…