初级排序算法之选择排序

初级排序算法

本质是对要排序的数组进行嵌套循环,内层循环负责局部的排序,外层循环负责剩余的无序元素的递减。所以你只要理解嵌套循环和比较大小就能很快的掌握初级排序算法。

选择排序

一个无序的数组 a = [0, 4, 6, 3, 8, 2, 3, 9], 你也可以把a的元素想象成任何现实中可比较的具体物体。例如,有10根长短不一的木条,我们如何对它们进行排序?一个最直接的思想,先拿出最短的放到最前面,在剩余的木条中再拿出最短的放在第二位...直到最后一根木条。从中我们可以看出,1. 我们需要再一次循环比较中找出一个最小的值(局部排序,每次找到的元素都是最小的和之前的元素组合起来就是有序的)。2,剔除掉这个最小的值,在剩余的值中重复第一步(无序的元素在递减,知道为0)。写成伪代码如下:

对数组a = [0, 4, 6, 3, 8, 2, 3, 9]进行选择排序

//对无序的元素进行循环递减。

for ( i = 0; i < a.length; i++)  //外层循环负责递减无序的元素

minIndex = i; //在此处我们需要先假设最小的元素在i位置上,至于真正的最小元素在哪里,有内循环负责找到

for ( j = i +1 ; j < a.length; j ++) //负责找到无序元素中的最小元素索引

    if ( a[minIndex] > a[j])

    minIndex = j

exchang(a, i, minIndex)  //exchang函数负责将数组中i, minIndex位置的元素进行交换。此时通过内循环我们找到了最小的元素,在外循环中我们将其放在了外循环的最前的位置,外循环遍历的无序元素个数减一。如此,当外循环走完,数组也就排序完成了。具体代码如下:

javascript版:

//封装常用的比较,交换函数
const utils = {
    less: function(a, b){
        return a < b;
    },
    exchange: function(arr, i, j){
        if(i === j) return;
        let tmp = arr[i];
        arr[i] = arr[j];
        arr[j] = tmp;
    }
};

//具体每一步的含义参考伪代码。
function sortArr(arr){
    let length = arr.length;
    for(let i = 0; i < length; i++){
        let minIndex = i;
        for(let j = i + 1; j < length; j++){
            if(utils.less(arr[j], arr[minIndex])){
                minIndex = j;
            }
        }
        utils.exchange(arr, i, minIndex);
    }
}

//生成随机无序的数组
function genArr(length){
    let arr = [];
    for(let i = 0; i < length; i++){
        arr.push(Math.floor(Math.random() * 1000));
    }
    return arr;
}

//测试排序函数
let arr = genArr(20);
console.log(`排序前的arr: ${arr}`);
sortArr(arr);
console.log(`排序后的arr: ${arr}`);

测试结果:

排序前的arr: 677,967,80,43,46,457,221,961,675,539,937,429,911,466,263,205,936,790,239,936
排序后的arr: 43,46,80,205,221,239,263,429,457,466,539,675,677,790,911,936,936,937,961,967

java版

import java.util.Arrays;

public class SelectSort{
    SelectSort(){
    }

    //封装常用的比较,交换, 创建无序数组的方法。
    public static final class SortUtils{
        public static boolean less(int a, int b){
            return a < b;
        }
        public static void exchange(int[] arr, int i, int j){
            if( i == j) return;
            int tmp = arr[i];
            arr[i] = arr[j];
            arr[j] = tmp;
        }
        public static int[] genArr(int length){
            int[] arr = new int[length];
            for(int i = 0; i < length; i++){
                arr[i] = (int)Math.floor(Math.random() * 1000);
            }
            return arr;
        }
    }
    public static void main(String[] args) {
        //创建无序数组
        int[] arr = SortUtils.genArr(10);
        System.out.println("排序前的arr: " +  Arrays.toString(arr));
        //排序
        sort(arr);
        System.out.println("排序后的arr: " +  Arrays.toString(arr));
    }

    public static void sort(int[] arr){
        int length = arr.length;
        for(int i = 0; i < length; i++){
            int minIndex = i;
            for(int j = i + 1; j < length; j++){
                if(SortUtils.less(arr[j], arr[minIndex])){
                    minIndex = j;
                }
            }
            SortUtils.exchange(arr, i, minIndex);
        }
    }
}

运行结果

排序前的arr: [416, 993, 557, 593, 208, 307, 533, 393, 607, 301]
排序后的arr: [208, 301, 307, 393, 416, 533, 557, 593, 607, 993]

Python版

import random
class Utils(object):
    def __ini__(self):
        pass
    @staticmethod
    def less(a, b):
        if(a > b):
            return False
        else:
            return True

    @staticmethod
    def exchange(arr, i, j):
        tmp = arr[i]
        arr[i] = arr[j]
        arr[j] = tmp

    @staticmethod
    def gen_arr(length):
        arr = []
        for i in range(length):
            arr.append(random.randint(0, 999))
        return arr

def sort(arr):
    length = len(arr)
    for i in range(length):
        min_index = i
        for j in range(i+1, length):
            if(Utils.less(arr[j], arr[min_index])):
                min_index = j

        Utils.exchange(arr, i, min_index)

if(__name__ == ‘__main__‘):
    #创建随机无序数组
    arr = Utils.gen_arr(10)
    print(‘排序前的arr: ‘, arr)
    sort(arr)
    print(‘排序后的arr: ‘, arr)

运行结果:

排序前的arr:  [139, 698, 787, 278, 434, 344, 265, 296, 878, 966]
排序后的arr:  [139, 265, 278, 296, 344, 434, 698, 787, 878, 966]

原文地址:https://www.cnblogs.com/chenzhenqi/p/10714323.html

时间: 2024-12-28 08:41:08

初级排序算法之选择排序的相关文章

数据结构排序算法之选择排序

今天继续介绍一种排序算法:选择排序. 选择排序的基本思想就是从待排序列中选择出最小的,然后将被选出元素和序列的第一个元素互换位置(当前默认是升序排列),则互换完成后第一个元素就是整个序列的最小的元素,则一次选择排序结束.然后我们从剩下的子序列中选择出最小的,然后将该被选出来的元素和该子序列的第一个元素(即整个序列的第二个元素)互换位置,则当前整个序列的第二个元素就是当前序列中的次最小值,第二次选择排序结束.以此类推,直到该待排序列只剩下一个元素后,则整个序列有序. 具体过程如下图所示: 下面就不

排序算法之选择排序

一. 算法描述 选择排序:在一个长度为N的无序数组中,在第一趟遍历N个数据,找出其中最小的数值与第一个元素交换,第二趟遍历剩下的N-1个数据,找出其中最小的数值与第二个元素交换......第N-1趟遍历剩下的2个数据,找出其中最小的数值与第N-1个元素交换,至此选择排序完成. 二. 算法分析 平均时间复杂度:O(n2) 空间复杂度:O(1)  (用于交换和记录索引) 稳定性:不稳定 (比如序列[5, 5, 3]第一趟就将第一个[5]与[3]交换,导致第一个5挪动到第二个5后面) 三. 算法实现

【排序算法】选择排序(Selection sort)

0. 说明 选择排序(Selection sort)是一种简单直观的排序算法. 它的工作原理如下. 首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾.以此类推,直到所有元素均排序完毕. 选择排序的主要优点与数据移动有关.如果某个元素位于正确的最终位置上,则它不会被移动.选择排序每次交换一对元素,它们当中至少有一个将被移到其最终位置上,因此对 n 个元素的表进行排序总共进行至多 n-1 次交换.在所有的完全依

【排序算法】选择排序

选择排序算法原理 选择排序算法时间复杂度分析 选择排序算法稳定性分析 选择排序算法C语言代码 #include <stdio.h> //交换两个元素的值 void swap(int* a, int* b) { int temp; temp = *a; *a = *b; *b = temp; } void selectionSort(int arr[], int length) { int i, j, maxIndex; for(i = length; i > 0; i--) { //假设

经典排序算法--简单选择排序

算法简介 简单选择排序是一种选择排序. 选择排序:每趟从待排序的记录中选出关键字最小的记录,顺序放在已排序的记录序列末尾,直到全部排序结束为止. 白话理解 依然已排队为例,在排队时,有的老师可能会选择这样排序,先在一列中选出最矮的,放在第一位,然后选出第二矮的,放在第二位.队伍完成排序.而这就是选择排序的思想. 简单排序处理流程 (1)从待排序序列中,找到关键字最小的元素: (2)如果最小元素不是待排序序列的第一个元素,将其和第一个元素互换: (3)从余下的 N - 1 个元素中,找出关键字最小

算法学习之排序算法:选择排序

选择排序:每一趟在n-i+1(i=1,2,...,n-1)个记录中选取关键字最小的记录作为有序序列中第i个记录. 一.简单选择排序 一趟选择排序操作: 通过n-i次关键字间的比较,从n-i+1个记录中选出关键字最小的记录,并和第i(1<=i<=n)个记录交换之. 对L[1...n]中记录进行简单选择排序的算法为:令i从1至n-1,进行n-1趟选择操作.简单选择排序过程中,所需进行记录移动的操作次数较少,然而,无论记录的初始排列如何,所需关键字间的比较次数相同.因此,总的时间复杂度为O(n^2)

排序算法——直接选择排序

直接选择排序每一趟排序都会从未排序的序列中选择出最小的元素来,然后跟未排序序列的第一个元素交换.这样经过n-1趟排序后,每趟排序选择出的 最小元素便成了有序的序列. 算法实现如下: #include <stdio.h> #include <stdlib.h> void SelectSort(int A[],int n) { int i, j, index, temp; for(i = 0; i < n-1; i++) // 进行n-1趟排序 { index = i; // 辅

排序算法总结------选择排序 ---javascript描述

每当面试时避不可少谈论的话题是排序算法,上次面试时被问到写排序算法,然后脑袋一懵不会写,狠狠的被面试官鄙视了一番,问我是不是第一次参加面试,怎么可以连排序算法都不会呢?不过当时确实是第一次去面试,以此恶补排序算法. 一.基本排序算法:基本排序算法有冒泡排序,选择排序,插入排序. 选择排序算法思想:选择排序从数组的头开始,将第一个元素与其他元素进行比较,找到最小的元素,然后放到数组的第一个位置.然后再从第二个元素开始找比他小的元素,放到第二个位置,以此类推,重复上述步骤,当进行到数组的第二个位置时

选择排序算法---直接选择排序和堆排序

本文主要是解析选择排序算法:直接选择排序和堆排序. 一.直接选择排序   基本思想:       选择排序(Selection sort)是一种简单直观的排序算法.它的工作原理如下.首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾.以此类推,直到所有元素均排序完毕. 选择排序的主要优点与数据移动有关.如果某个元素位于正确的最终位置上,则它不会被移动.选择排序每次交换一对元素,它们当中至少有一个将被移到其最终