视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
无线网速度慢提速可以怎么弄 word文档怎么去掉回车符号 微信自动收钱怎么设置 七星瓢虫简笔画 airpods怎么看充电 电脑上该咋安装flashplayer 手机qq撤回的图片可以咋进行查看 微信不是好友能看见朋友圈吗 咋进行修改ppt的模板文字 excel上要咋进行自动排序123 苹果怎么把电话号码导入新手机 手机电池是不是锂电池 PS里的图层要怎样旋转 word图片的文字怎么提取出来 cdr如何才能居中 笔记本wifi显示有限访问权限是怎么回事 Win10上的命令提示符可以如何打开 手机微信恢复聊天记录如何恢复 电脑上的word文档如何进行新建 wifi分享二维码用什么扫 小米手机设置地震提醒如何设置 手机咋样投屏到电脑 换手机登录微信后如何恢复聊天记录 微博怎么改手机型号显示设置 linux删除文件夹命令 WPS该咋的才可以查找关键字 Win10要怎么显示隐藏文件 苹果id密码如何才能修改 小米手机该如何打开地震提醒 etc怎么查询收费记录查询 word表格中所有文字居中怎么设置 手机版wps怎么写文档 如何处理笔记本WiFi功能消失 怎么样关闭拼小圈 微信如何查看自动扣费的业务 wps怎么取消限制条件 b站视频怎么才能保存在手机本地 qq强制解绑手机号 PPT的演讲者模式可以怎么进行设置 小米手机设置地震提醒怎么设置
c语言选择法排序讲解
2022-08-04 23:17:36 责编:小采
文档

排序算法是《数据结构与算法》中最基本的算法之一。排序算法可以分为内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部的排序记录,在排序过程中需要访问外存。常见的内部排序算法有:插入排序、希尔排序、选择排序、冒泡排序、归并排序、快速排序、堆排序、基数排序等。以下是选择排序算法:

选择排序是一种简单直观的排序算法,无论什么数据进去都是 O(n?) 的时间复杂度。所以用到它的时候,数据规模越小越好。唯一的好处可能就是不占用额外的内存空间了吧。

1. 算法步骤

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

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

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

2. 动图演示


代码实现

JavaScript 代码实现

实例

function selectionSort(arr) {
    var len = arr.length;
    var minIndex, temp;
    for (var i = 0; i < len - 1; i++) {
        minIndex = i;
        for (var 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;
}

Python 代码实现

实例

def selectionSort(arr):
    for i in range(len(arr) - 1):
        # 记录最小数的索引
        minIndex = i
        for j in range(i + 1, len(arr)):
            if arr[j] < arr[minIndex]:
                minIndex = 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 < length-1; i++ {
                min := i
                for j := i + 1; j < length; 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 < arr.length - 1; i++) {
            int min = i;

            // 每轮需要比较的次数 N-i
            for (int j = i + 1; j < arr.length; j++) {
                if (arr[j] < arr[min]) {
                    // 记录目前能找到的最小值元素的下标
                    min = j;
                }
            }

            // 将找到的最小值和i位置所在的值进行交换
            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 < len - 1 ; i++)
    {
                int min = i;
                for (j = i + 1; j < len; j++)     //走訪未排序的元素
                        if (arr[j] < arr[min])    //找到目前最小值
                                min = j;    //紀錄最小值
                swap(&arr[min], &arr[i]);    //做交換
        }
}

C++

实例

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

C#

实例

static void selection_sort<T>(T[] arr) where T : System.IComparable<T>{//整數或浮點數皆可使用
        int i, j, min, len = arr.Length;
        T temp;
        for (i = 0; i < len - 1; i++) {
                min = i;
                for (j = i + 1; j < len; 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..<list.count - 1 {
        var minIndex = j
        for i in j..<list.count {
            if list[minIndex] > list[i] {
                minIndex = i
            }
        }
        list.swapAt(j, minIndex)
    }
}

原文地址:https://github.com/hustcc/JS-Sorting-Algorithm/blob/master/2.selectionSort.md

参考地址:https://zh.wikipedia.org/wiki/%E9%80%89%E6%8B%A9%E6%8E%92%E5%BA%8F

以下是热心网友对选择排序算法的补充,仅供参考:

热心网友提供的补充1:

Kotlin 实现

class SelectionSort { 
    /** 
    * 拓展IntArray为他提供数据两个数交换位置的方法 
    * @param i 第一个数的下标 
    * @param j 第二个数的下标 
    */ 
    fun IntArray.swap(i:Int,j:Int){ 
        var temp=this[i] 
        this[i]=this[j] 
        this[j]=temp 
    } 
    fun selectionSort(array: IntArray):IntArray{
        for (i in array.indices){ 
            //假设最小值是i 
            var min=i 
            var j=i+1 
            while (j in array.indices){ 
                if (array[j]<array[min]){ 
                    min=j
                }
                j++ 
            } 
            if (i!=min){
                array.swap(i,min) 
            } 
        } 
        return array; 
    }
}
以上为选择排序算法详细介绍,插入排序、希尔排序、选择排序、冒泡排序、归并排序、快速排序、堆排序、基数排序等排序算法各有优缺点,用一张图概括:

关于时间复杂度

平方阶 (O(n2)) 排序 各类简单排序:直接插入、直接选择和冒泡排序。

线性对数阶 (O(nlog2n)) 排序 快速排序、堆排序和归并排序;

O(n1+§)) 排序,§ 是介于 0 和 1 之间的常数。 希尔排序

线性阶 (O(n)) 排序 基数排序,此外还有桶、箱排序。

关于稳定性

稳定的排序算法:冒泡排序、插入排序、归并排序和基数排序。

不是稳定的排序算法:选择排序、快速排序、希尔排序、堆排序。

名词解释:

n:数据规模

k:"桶"的个数

In-place:占用常数内存,不占用额外内存

Out-place:占用额外内存

稳定性:排序后 2 个相等键值的顺序和排序之前它们的顺序相同

下载本文
显示全文
专题什么是化妆品什么是化妆品专题怎样选择祛斑化妆品怎样选择祛斑化妆品专题夏季如何正确保存化妆品夏季如何正确保存化妆品专题过期化妆品再利用过期化妆品再利用专题教育培训机构选址技巧教育培训机构选址技巧专题教育培训机构三大经营技巧教育培训机构三大经营技巧专题教育培训机构如何做网络推广教育培训机构如何做网络推广专题教育培训机构网络营销策略教育培训机构网络营销策略专题布艺家具巧利用布艺家具巧利用专题别致布艺家具装点小资柔情别致布艺家具装点小资柔情专题布艺家具保养使用方法布艺家具保养使用方法专题化妆品加工定义与模式及专业术语的介绍化妆品加工定义与模式及专业术语的介绍专题化妆品基础知识简述化妆品基础知识简述专题化妆品的选购误区化妆品的选购误区专题教你怎样辨别化妆品好坏的小窍门教你怎样辨别化妆品好坏的小窍门专题化妆品是什么时候出现的化妆品是什么时候出现的专题化妆品的发展历史化妆品的发展历史专题化妆品的分类(一)化妆品的分类(一)专题化妆品中中草药的作用化妆品中中草药的作用专题化妆品收纳盒有用吗化妆品收纳盒有用吗专题怎样选购一款好的化妆品收纳盒怎样选购一款好的化妆品收纳盒专题妇女怀孕后使用化妆品注意妇女怀孕后使用化妆品注意专题化妆品禁用语化妆品禁用语专题化妆品原料简介化妆品原料简介专题化妆品油质原料简介(一)化妆品油质原料简介(一)专题化妆品胶质原料简介化妆品胶质原料简介专题化妆品也有寿命化妆品也有寿命专题化妆品里的成分化妆品里的成分专题选购化妆品应该注意什么选购化妆品应该注意什么专题网购化妆品可靠吗网购化妆品可靠吗专题