详解选择排序

选择排序(Selection sort)是一种简单直观的排序算法。其基本思想是:首先在未排序的数列中找到最小(or最大)元素,然后将其存放到数列的起始位置;接着,再从剩余未排序的元素中继续寻找最小(or最大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。

算法步骤

首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置。

再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。

重复第二步,直到所有元素均排序完毕。

动图演示

什么是选择排序?什么是选择排序?

代码实现

JavaScript 代码实现

实例

function selectionSort(arr) {
   var len = arr.length;
   var minIndex, temp;
   for (var i = 0; i for (var j = i + 1; j if (arr[j] return arr;
}

Python 代码实现

实例

def selectionSort(arr):
   for i in range(len(arr) - 1):
       # 记录最小数的索引
       minIndex = i
       for j in range(i + 1, len(arr)):
           if arr[j] # i 不是最小数时,将 i 和最小数进行交换
       if i != minIndex:
           arr[i], arr[minIndex] = arr[minIndex], arr[i]
   return arr

Go 代码实现

实例

func selectionSort(arr []int) []int {
       length := len(arr)
       for i := 0; i for j := i + 1; j if arr[min] > arr[j] {
                               min = j
                       }
               }
               arr[i], arr[min] = arr[min], arr[i]
       }
       return arr
}

Java 代码实现

实例

public class SelectionSort implements IArraySort {

   @Override
   public int[] sort(int[] sourceArray) throws Exception {
       int[] arr = Arrays.copyOf(sourceArray, sourceArray.length);

       // 总共要经过 N-1 轮比较
       for (int i = 0; i for (int j = i + 1; j if (arr[j] if (i != min) {
               int tmp = arr[i];
               arr[i] = arr[min];
               arr[min] = tmp;
           }

       }
       return arr;
   }
}

PHP 代码实现

实例

function selectionSort($arr)
{
   $len = count($arr);
   for ($i = 0; $i $len - 1; $i++) {
       $minIndex = $i;
       for ($j = $i + 1; $j $len; $j++) {
           if ($arr[$j] $arr[$minIndex]) {
               $minIndex = $j;
           }
       }
       $temp = $arr[$i];
       $arr[$i] = $arr[$minIndex];
       $arr[$minIndex] = $temp;
   }
   return $arr;
}

C 语言

实例

void swap(int *a,int *b) //交換兩個變數
{
   int temp = *a;
   *a = *b;
   *b = temp;
}
void selection_sort(int arr[], int len)
{
   int i,j;

       for (i = 0 ; i for (j = i + 1; j if (arr[j] 

C++

实例

template //整數或浮點數皆可使用,若要使用物件(class)時必須設定大於(>)的運算子功能
void selection_sort(std::vector& arr) {
       for (int i = 0; i for (int j = i + 1; j if (arr[j] 

C#

实例

static void selection_sort(T[] arr) where T : System.IComparable{//整數或浮點數皆可使用
       int i, j, min, len = arr.Length;
       T temp;
       for (i = 0; i for (j = i + 1; j if (arr[min].CompareTo(arr[j]) > 0)
                               min = j;
               temp = arr[min];
               arr[min] = arr[i];
               arr[i] = temp;
       }
}

Swift

实例

import Foundation
/// 选择排序
///
/// - Parameter list: 需要排序的数组
func selectionSort(_ list: inout [Int]) -> Void {
   for j in 0..
  
   for i 
   in j..
   
    if list[minIndex] > list[i] {                minIndex = i            }        }        list.swapAt(j, minIndex)    } } 
   
  

原创文章,作者:晴川运维,如若转载,请注明出处:https://baike.qcidc.com/16185.html

(0)
晴川运维晴川运维
上一篇 2025年10月21日
下一篇 2025年10月21日

相关推荐

  • static关键字的使用方法

    static,即静态声明。它在 作用域、存储方式、生命周期 等各方面影响一个变量或函数。文章将从 局部变量、全局变量、普通函数、类的static成员(包括数据成员与成员函数)来总结…

    Linux系统 2025年10月9日
  • Linux查看硬件信息(制造商、型号和序列号)具体方法

    用过Linux系统的人都知道这么一个情况,那就是Linux大部分操作是通过命令实现的,并不像Windows那么直观。linux查看硬件信息也是需要通过命令查询才可以看得到硬件的信息…

    Linux系统 2025年6月11日
  • 详解cat、more、less命令区别

    cat、more、less命令都是用来查看文本内容的命令,但是他们的使用方法和特点各有不同,本篇文章就为大家讲解一下cat more less的区别。 cat cat命令功能用于显…

    Linux系统 2025年10月6日
  • 详解Linux系统IO分析工具iotop

    iotop是linux系统下测试硬盘IO读写的工具,简单的说,iotop是一个用来监视磁盘I/O使用状况的 top 类工具,可监测到哪一个程序使用的磁盘IO的信息(requires…

    Linux系统 2025年10月25日
  • Python3 re模块match与search

    正则表达式(regular expression)描述了一种字符串匹配的模式(pattern),可以用来检查一个串是否含有某种子串、将匹配的子串替换或者从某个串中取出符合某个条件的…

    Linux系统 2025年7月10日
  • Java随机数的坑你踩过吗

    随机数我们应该不陌生,业务中我们用它来生成验证码,或者对重复性要求不高的id,甚至我们还用它在年会上搞抽奖。今天我们来探讨一下这个东西。如果使用不当会引发一系列问题。 随机数我们应…

    Linux系统 2025年10月5日
  • Linux下使用Linfo显示服务器运行状况

    Linfo 是一个自由开源的跨平台的服务器统计 UI 或库,它可以显示大量的系统信息。Linfo 是可扩展的,通过 composer,很容易使用 PHP5 库以程序化方式获取来自 …

    Linux系统 2025年6月8日
  • 五大最流行的配置管理工具

    了解一下配置管理工具,以找出哪个最适合你的 DevOps 组织。 DevOps 正因为有提高产品质量、缩短产品开发时间等优势,目前备受业界关注,同时也在长足发展当中。 DevOps…

    Linux系统 2025年10月27日
  • Linux下安装php运行环境—phpstudy

    phpstudy是一个php运行环境的集成包,用户不需要去配置运行环境,就可以使用,phpstudy不仅是一款比较好用的php调试环境工具,并且还包括了开发工具和常用手册,对于新手…

    Linux系统 2025年9月22日
  • 详解oracle运算符

    oracle数据库中的数据,在查询的时候,通常不是一个条件就能过滤出想要的结果,那么,当需要指定多个复杂的过滤条件时and、or连接运算符就派上用场了,本篇文章重点为大家讲解一下o…

    Linux系统 2025年6月10日

发表回复

登录后才能评论