十大经典排序算法之选择排序。

​ 选择排序(Selection Sort)是一种简单直观的排序算法,它的基本思想是通过重复从未排序的部分选择最小(或最大)的元素,并将其放到已排序部分的末尾,直到整个列表都排序完成,也就是说,他先把数组先分成了两个部分,一个是有序的,一个是无序的,如果我们是从小到大排序,那么每次都从未排序的部分中找到最小的,然后放到有序的部分中。

选择排序的基本步骤如下:

  1. 首先,假设整个列表为未排序部分。
  2. 在未排序部分中,找到最小(或最大)的元素,并将其与未排序部分的第一个元素交换位置,使得该最小(或最大)元素成为已排序部分的最后一个元素。
  3. 然后,将未排序部分的范围缩小一个元素,继续执行步骤2,直到整个列表都排序完成。
  4. 时间复杂度为 O(n^2)。

接下里我们给出一段选择排序的示例c代码

void select_sort(int *array, int array_num)
{int				i = 0;int				j = 0;int				pos = 0;   int				temp = 0;  printf("select sorting\n");for (i=0; i<array_num; i++){pos = i;//找到最小的数字对应的那个数组角标for (j=i+1; j<array_num; j++){if ( array[j]<array[pos] ){pos = j;}}temp = array[i];array[i] = array[pos];array[pos] = temp;}
}

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

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

相关文章

基于Springboot的web后端开发三层架构上手实操

引言 我们拿到了xml文件 我们要将将xml文件中的数据加载并解析 完成数据的处理 并且返回给前端页面(result格式) 1.将xml文件放在resources目录下 xml是我们需要解析的文件 查看xml文件 2.在springboot中引入dom4j依赖 解析xml需要在springboot中引入dom4j依赖 这边我们…

Thread类的基本用法

1.线程创建 这里介绍线程创建常用的五种方法 1.继承Thread&#xff0c;重写run class MyThread extends Thread{public void run(){//这里写的代码就是线程要完成的任务while (true){System.out.println("hello thread");try {Thread.sleep(1000);//线程会休眠一秒…

二维码门楼牌管理应用平台建设:取保候审人员管理的新模式

文章目录 前言一、取保候审人员管理的新挑战二、二维码门楼牌管理应用平台的引入三、平台的功能与应用四、优势与挑战五、结论 前言 随着科技的不断进步&#xff0c;二维码门楼牌管理应用平台已成为城市管理的创新手段。特别是在取保候审人员管理领域&#xff0c;这一技术的应…

电视盒子哪款好?实体店主盘点畅销电视盒子排名

电视盒子功能丰富&#xff0c;是升级电视机最具性价比的方案。我本人做实体数码店多年来&#xff0c;电视盒子是店内销量最好的产品之一&#xff0c;最近很多网友在讨论电视盒子哪款好&#xff0c;我整理了店内销量最好的电视盒子排名&#xff0c;想买电视盒子可以看看下面这几…

海外盲盒App开发:探索全球惊喜,开启无限可能

一、前言 随着全球化的深入发展&#xff0c;人们对于不同文化、不同地域的商品充满了好奇与向往。盲盒文化&#xff0c;作为一种充满神秘与惊喜的消费方式&#xff0c;正逐渐在全球范围内受到热烈追捧。为了满足海外用户对于盲盒的需求&#xff0c;我们团队精心策划并开发了一…

读写锁ReentrantReadWriteLockStampLock详解

现实中有这样一种场景&#xff1a;对共享资源有读和写的操作&#xff0c;且写操作没有读操作那么频繁&#xff08;读多写少&#xff09;。在没有写操作的时候&#xff0c;多个线程同时读一个资源没有任何问题&#xff0c;所以应该允许多个线程同时读取共享资源&#xff08;读读…

盲人安全过马路:科技赋能,独立出行不再难

作为一位资深记者&#xff0c;我长期关注特殊群体的生活现状与科技助力下的改善举措。今天&#xff0c;我要讲述的是盲人朋友在独立出行&#xff0c;尤其是过马路时面临的挑战&#xff0c;以及一款叫做蝙蝠避障的创新辅助应用如何通过实时避障与拍照识别功能&#xff0c;显著提…

深入解读Dubbo:微服务RPC框架的佼佼者

在微服务盛行的今天&#xff0c;RPC&#xff08;远程过程调用&#xff09;框架的重要性日益凸显。Dubbo&#xff0c;作为阿里巴巴公司开源的一款高性能、轻量级的Java RPC框架&#xff0c;已经成为众多企业构建微服务架构的首选。作为一名资深的架构师&#xff0c;我深知Dubbo在…

IntelliJ IDEA 如何启用 JDK 预览特性

IntelliJ IDEA 也可以启用 JDK 的预览特性。 针对项目&#xff0c;选择项目结构。 配置是在语言结构上。 单击语言结构上的 SDK 默认&#xff0c;往下拉&#xff0c;就可以看到针对新版本的选项。 同时还可以看到那些版本是支持新特性预览的&#xff0c;那些版本是不支持新特…

Vue报错 Cannot read properties of undefined (reading ‘websiteDomains‘) 解决办法

浏览器控制台如下报错&#xff1a; Unchecked runtime.lastError: The message port closed before a response was received. Uncaught (in promise) TypeError: Cannot read properties of undefined (reading websiteDomains) at xl-content.js:1:100558 此问题困扰了…

多目标粒子群算法及其MATLAB实现

多目标粒子群优化&#xff08;Multi-Objective Particle Swarm Optimization, MOPSO&#xff09;算法是一种基于种群的优化算法&#xff0c;它结合了粒子群优化&#xff08;Particle Swarm Optimization, PSO&#xff09;和多目标优化的思想。多目标粒子群&#xff08;MOPSO&am…

PCL:投影滤波器

1.介绍 在点云处理中,投影滤波器是一种常用的工具,它可以将点云投影到给定的模型上,并保留投影后的点云数据。 投影滤波器主要应用于以下场景: 平面投影:将点云投影到一个已知的平面上,以获取平面上的点云数据。几何模型投影:将点云投影到已知的几何模型上,如圆柱体、…

IP地址信息——IP地址、子网掩码、默认网关和DNS

IP地址信息 通常来说&#xff0c;一个完整的IP地址信息应该包括IP地址、子网掩码、默认网关和DNS等4部分内容&#xff0c;只有当它们各司其职、协同工作时&#xff0c;我们才可以访问Internet&#xff0c;并被Internet中的计算机所访问。需要注意的是&#xff0c;采用静态IP地…

开发工具-pycharm的代码自动部署服务器以及服务端python配置、项目开发环境一键启动服务

文章目录 一、pycharm的ssh配置1.本地生成ssh密钥2.密钥配置到远端服务器(1-1) 有权限ssh访问到服务器(1-2) 无权限ssh访问到服务器(1-3) 没有办法通过以上形式上传到服务器(2) 配置到authorized_keys自动访问 3.pycharm中配置ssh(1) 选择File中的settings(1) 选择Tools中的SSH…

在 React Router v5 中,写子路由,父级路由如果加了exact属性,就显示不了子组件

在 React Router v5 中&#xff0c;当你在父级路由上使用 exact 属性时&#xff0c;它意味着该路由只有在其 path 完全匹配当前 URL 时才会被激活。这意味着&#xff0c;如果父级路由精确匹配了&#xff0c;React Router 就不会继续向下查找子路由&#xff0c;因为 exact 限制了…

js的算法-插入排序(折半插入排序)

直接插入排序的步骤 1. 从前面的有序子表中查找出待插入元素应该被插入的位置 2. 给插入位置腾空间 3. 将待插入元素复制到表中的插入位置。 直接插入排序&#xff1a;边比较边移动&#xff1b; 折半插入排序 先折半查找出元素的待插入位置&#xff0c;然后统一地移动待插…

上位机图像处理和嵌入式模块部署(树莓派4b之远程vnc桌面访问)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 对于很多嵌入式开发比较精通的同学来说&#xff0c;使用命令行和开发板之间进行沟通是他们完全能够接受的一种开发方式。但是对于更多的朋友来说&a…

AI编码prompt编写及内在逻辑

最近在做一个项目&#xff0c;涉及AI编码表和标准码表。那么什么AI编码表&#xff0c;什么是标准码表&#xff0c;AI编码表生成的逻辑是什么呢&#xff1f; 文章目录 1. 什么是AI编码表&#xff0c;什么是标准码表&#xff1f;2. AI编码码表的生成逻辑是怎么样的&#xff1f;3.…

0425DormAJAX项目

0425DormAJAX项目包-CSDN博客 数据库字段 添加界面&#xff1a; 初始状态&#xff1a; 点击性别&#xff0c;宿舍号使用ajax动态添加&#xff1a; 学生主界面&#xff1a; 实现分页查询&#xff1a; 点击修改学生宿舍&#xff0c;查看换寝记录&#xff0c;ajax动态显示列表&…

【设计模式】发布订阅模式,构建可以接收历史消息的观察者类

什么是发布订阅模式&#xff1f; 发布订阅模式也被称为观察者模式&#xff0c;这个模式中有两种角色&#xff1a;发布者&#xff08;被观察者&#xff09; 和 订阅者&#xff08;观察者&#xff09;。 通常的操作是&#xff1a;订阅者订阅发布者的某一个事件&#xff0c;发布…