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

排序算法之-选择

算法原理

在未排序的数列中找出最大(或最小)的元素,然后将其存入到已排序的数列起始位置,紧接着在剩余的未排序数列中继续查找最大(或最小)的元素,并将其放入到已排序的数列末尾,依次类推,直至未排序的数列中没有元素。

算法图解

在这里插入图片描述

算法实现

public class SelectionSort {public void sort(int arr[]){int startIndex = 0;while (startIndex < arr.length-1){int minValue = arr[startIndex];int minIndex = startIndex;for(int i=startIndex+1;i<arr.length;i++){if(minValue > arr[i]){minValue = arr[i];minIndex = i;}}if(startIndex != minIndex){int temp = arr[minIndex];arr[minIndex] = arr[startIndex];arr[startIndex]=temp;}startIndex++;}}
}

测试

public static void main(String[] args) {int arr[] = {9,7,1991,27,-1,-10,0,2,65,-100};SelectionSort selectionSort = new SelectionSort();selectionSort.sort(arr);for(int i = 0;i<arr.length;i++){System.out.print(arr[i]+"\t");}}

结果

在这里插入图片描述

相关文章:

排序算法之-选择

算法原理 在未排序的数列中找出最大&#xff08;或最小&#xff09;的元素&#xff0c;然后将其存入到已排序的数列起始位置&#xff0c;紧接着在剩余的未排序数列中继续查找最大&#xff08;或最小&#xff09;的元素&#xff0c;并将其放入到已排序的数列末尾&#xff0c;依…...

机器学习模板代码(期末考试复习)自用存档

机器学习复习代码 利用sklearn实现knn import numpy as np import pandas as pd from sklearn.neighbors import KNeighborsClassifier from sklearn.model_selection import GridSearchCVdef model_selection(x_train, y_train):## 第一个是网格搜索## p是选择查找方式:1是欧…...

使用sizeof()和strlen()去计算【数组】和【指针】的大小

文章目录 一、知识回顾1、回顾sizeof()、strlen的作用&#xff1a;2、数组和指针3、数组名 二、sizeof()、strlen()的使用区别1、注意区别&#xff1a;2、一维数组与一级指针3、二维数组与二级指针 三、总结回顾 一、知识回顾 1、回顾sizeof()、strlen的作用&#xff1a; siz…...

viple进阶4:打印空心三角形

题目&#xff1a;根据用户输入的行数n打印空心三角形&#xff0c;下图分别为n3、n4、n5和n10的效果图 第一步&#xff1a;观察效果图 输入的行数为3&#xff0c;打印结果就有3行&#xff1b;输入的行数为4&#xff0c;则打印结果就有4行&#xff1b;以此类推&#xff0c;输入的…...

Oauth2.0的内容

OAuth 2.0是一个授权协议&#xff0c;用于允许第三方应用程序访问用户在另一个应用程序上存储的受保护资源&#xff0c;而不需要将用户名或密码公开给第三方应用程序。 OAuth2.0基于客户端-服务器模型&#xff0c;通常需要三个主体&#xff1a;客户端、资源所有者和授权服务器…...

npm 下载包失败解决方案

1.【问题描述】使用 npm 下载vue项目依赖包时失败&#xff0c;版本不一致。 【解决方法】使用 npm install --force npm install --force 是一个命令行指令&#xff0c;用于在 Node.js 环境中使用 npm&#xff08;Node Package Manager&#xff09;安装包或模块。–force 参数表…...

C语言---插入排序、希尔排序、冒泡排序、选择排序、快速排序简单介绍

文章目录 插入排序希尔排序冒泡排序选择排序快速排序 本文主要介绍用C语言实现的一些排序方法&#xff0c;有插入排序、希尔排序、冒泡排序、选择排序和快速排序&#xff0c;文章中给出的例子都是按照升序排列的。 插入排序 若数组只有一个元素&#xff0c;自然不用排序&#…...

撸视频号收益这个副业靠谱吗?

我是卢松松&#xff0c;点点上面的头像&#xff0c;欢迎关注我哦&#xff01; 昨天有个人问我说做视频号能月入过万吗? 我的回复是&#xff1a;99%的人不能。 但为什么会经常有人这么问呢&#xff0c;松松思考了一下&#xff0c;原因是最近很多人在晒视频号撸收益的项目&am…...

2、数组、Map+HashMap、Set+Hashset、Char和Character类、String类和Char类、Math类

数组 \\一个普通的长度为1的整数数组 Integer[] arr new Integer[1];\\一个普通长度为1的同时元素初始化为1的整数数组。 Integer[] arr new Integer[]{1};\\一个长度为0的空数组 Integer[] arr new Integer[0];Map 常见方法 void clear( ) 从此映射中移除所有映射关系&#…...

ESP8266 WiFi模块快速入门指南

ESP8266是一种低成本、小巧而功能强大的WiFi模块&#xff0c;非常适合于物联网和嵌入式系统应用。本指南将为您提供关于ESP8266 WiFi模块的快速入门步骤和基本知识。 第一步&#xff1a;硬件准备 首先&#xff0c;您需要将ESP8266 WiFi模块与您的开发板连接。通常情况下&#…...

微信小程序将后端返回的图片文件流解析显示到页面

说明 由于请求接口后端返回的图片格式不是一个完整的url,也不是其他直接能显示的图片格式&#xff0c;是一张图片 后端根据模板与二维码生成图片,返回二进制数据 返回为文件流的格式,用wx.request请求的时候&#xff0c;就自动解码成为了下面这样的数据数据格式,这样的数据没…...

网络基础(1)

目录&#xff1a; 1.了解局域网&#xff08;LAN&#xff09;和广域网&#xff08;WAN&#xff09; 2.认识“协议” 3.浅谈OSI七层模型 4.网络传输的基本流程 5.路由器这个设备 ---------------------------------------------------------------------------------------…...

flink的AggregateFunction,merge方法作用范围

背景 AggregateFunction接口是我们经常用的窗口聚合函数&#xff0c;其中有一个merge方法&#xff0c;我们一般情况下也是实现了的&#xff0c;但是你知道吗&#xff0c;其实这个方法只有在你使用会话窗口需要进行窗口合并的时候才需要实现 AggregateFunction.merge方法调用时…...

Day25力扣打卡

打卡记录 寻找旋转排序数组中的最小值&#xff08;二分&#xff09; 链接 由于是旋转排序数组&#xff0c;所以整个数组有两部分是递增的&#xff0c;选取右侧最后元素&#xff0c;即可将整个数组分为大于该元素和小于该元素&#xff0c;碰头地段即为最小值。 class Solutio…...

SpringCloud - OpenFeign 参数传递和响应处理(全网最详细)

目录 一、OpenFeign 参数传递和响应处理 1.1、feign 客户端参数传递 1.1.1、零散类型参数传递 1. 例如 querystring 方式传参 2. 例如路径方式传参 1.1.2、对象参数传递 1. 对象参数传递案例 1.1.3、数组参数传递 1. 数组传参案例 1.1.4、集合类型的参数传递&#xf…...

Postgresql数据类型-布尔类型

前面介绍了PostgreSQL支持的数字类型、字符类型、时间日期类型&#xff0c;这些数据类型是关系型数据库的常规数据类型&#xff0c;此外PostgreSQL还支持很多非常规数据类型&#xff0c;比如布尔类型、网络地址类型、数组类型、范围类型、json/jsonb类型等&#xff0c;从这一节…...

SPASS-交叉表分析

导入数据 修改变量测量类型 分析->描述统计->交叉表 表中显示行、列变量通过卡方检验给出的独立性检验结果。共使用了三种检验方法。上表各种检验方法显著水平sig.都远远小于0.05,所以有理由拒绝实验准备与评价结果是独立的假设&#xff0c;即认为实验准备这个评价指标是…...

用Python的requests库来模拟爬取地图商铺信息

由于谷歌地图抓取商铺信息涉及到API使用和反爬虫策略&#xff0c;直接爬取可能会遇到限制。但是&#xff0c;我们可以使用Python的requests库来模拟爬取某个网页&#xff0c;然后通过正则表达式或其他文本处理方法来提取商铺信息。以下是一个简单的示例&#xff1a; # 导入requ…...

使用EvoMap/Three.js模拟无人机灯光秀

一、创建地图对象 首先我们需要创建一个EM.Map对象&#xff0c;该对象代表了一个地图实例&#xff0c;并设置id为"map"的文档元素作为地图的容器。 let map new EM.Map("map",{zoom:22.14,center:[8.02528, -29.27638, 0],pitch:71.507,roll:2.01,maxPit…...

11.9存储器实验总结(单ram,双ram,FIFO)

实验设计 单端口RAM实现 双端口RAM实现 FIFO实现 文件结构为...

一款简约高效导航系统源码v2.0.1

内容目录一、详细介绍二、效果展示1.部分代码2.效果图展示请添加图片描述三、学习资料下载一、详细介绍 这是一款简约高效导航系统源码&#xff0c;这套源码作者是听风写的系统&#xff0c;很简约&#xff0c;更新了 2.0.1 版本&#xff0c; 更新了前 / 后台刷新加载有特效效…...

AutoHotKey循环实战:用While和Loop实现一个“按住测量”的屏幕标尺工具(附完整脚本)

AutoHotKey循环实战&#xff1a;用While和Loop实现“按住测量”屏幕标尺工具 在UI设计、网页排版或视频编辑场景中&#xff0c;经常需要快速测量屏幕上两个点之间的距离或某个区域的像素尺寸。专业设计软件通常内置标尺工具&#xff0c;但切换软件往往打断工作流。今天我们将用…...

从混淆矩阵到决策曲线:用Matplotlib一步步拆解DCA背后的净获益计算

从混淆矩阵到决策曲线&#xff1a;用Matplotlib拆解DCA的净获益计算 在医疗诊断和风险评估领域&#xff0c;我们常常需要判断一个预测模型是否真正具有临床价值。传统指标如准确率、AUC值虽然能反映模型性能&#xff0c;却无法回答一个关键问题&#xff1a;**使用这个模型做决策…...

Obsidian Excel插件终极指南:在笔记中无缝嵌入和管理电子表格

Obsidian Excel插件终极指南&#xff1a;在笔记中无缝嵌入和管理电子表格 【免费下载链接】obsidian-excel 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian-excel 你是否经常在Obsidian笔记和Excel表格之间来回切换&#xff0c;只为整理几个简单的数据&#xf…...

awesome-intelligence实战案例:如何追踪网络攻击者

awesome-intelligence实战案例&#xff1a;如何追踪网络攻击者 【免费下载链接】awesome-intelligence A collaboratively curated list of awesome Open-Source Intelligence (OSINT) Resources 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-intelligence 在网…...

17.3【保姆级教程】宏和函数的选择:时间与空间的权衡,新手不踩坑指南

&#x1f4e2; 专栏持续更新中&#xff01;关注博主不迷路&#xff0c;跟着专栏系统学C语言底层开发&#xff0c;从语法入门到工程实战&#xff0c;逐章拆解&#xff0c;保姆级讲解&#xff0c;刚入门的同学跟着学&#xff0c;全程零压力&#xff5e; 上一节我们详细掌握了 #de…...

5分钟极速转换:m4s-converter无损视频格式转换解决方案

5分钟极速转换&#xff1a;m4s-converter无损视频格式转换解决方案 【免费下载链接】m4s-converter 一个跨平台小工具&#xff0c;将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 你是否遇到过这样的情况&…...

Python实战:用NetworkX可视化TSP问题,手把手教你实现最邻近与插入算法

Python实战&#xff1a;用NetworkX可视化TSP问题&#xff0c;手把手教你实现最邻近与插入算法 当你在规划一次跨越多个城市的旅行路线时&#xff0c;如何找到最短的路径&#xff1f;这就是经典的旅行商问题&#xff08;TSP&#xff09;。作为组合优化领域的著名难题&#xff0c…...

Ray Serve 模型推理部署(上)

第六章:Ray Serve 模型推理部署(上) 6.1 部署架构与核心概念 Ray Serve 是 Ray 生态中专门用于模型推理和服务部署的库。它提供了可扩展、可编程的模型服务框架,支持实时推理和批量推理两种模式。Ray Serve 的设计目标是让开发者能够轻松地将训练好的模型部署到生产环境,同…...

【嵌入式】轻量级命令行交互实战:nr_micro_shell在资源受限MCU上的移植与优化

1. 为什么选择nr_micro_shell&#xff1f; 在嵌入式开发中&#xff0c;调试和维护是绕不开的环节。想象一下&#xff0c;当你需要实时查看某个传感器的数值&#xff0c;或者临时调整某个参数时&#xff0c;如果每次都要重新烧录程序&#xff0c;那效率得多低啊&#xff01;这时…...