zoukankan      html  css  js  c++  java
  • 排序算法——选择排序

    写在前面

    除了冒泡排序外的第二简单的排序算法就是选择排序了。选择排序的思路就是每次从前往后或从后往前依次确定一个数的位置,确定的方法就是将那个位置的数单独拎出来和其余未确定位置的数据依次进行比较和交换,来最终确定该位置的数。比如,第一趟从中选择出一个最小的数,将其放在第一个位置,第二趟从剩余的数中再次选择出一个最小的数据,放在第二的位置,以此类推。

    选择排序也是比较 n-1 趟

    1. 选择排序

    选择排序只是一个思路,具体实现方式有很多,比如下方的每次记录最小数的下标,一趟比较完后才交换位置。

    function sort(arr){
        for(let i = 0; i < arr.length-1; i++){
            let min = i
            for(let j = i+1; j < arr.length; j++){
                if(arr[j] < arr[min]){
                    min = j
                }
            }
            let temp = arr[i]
            arr[i] = arr[min]
            arr[min] = temp
        }
        return arr
    }
    

    平均时间复杂度:O(n^2), 最好时间复杂度:O(n),最差时间复杂度:O(n^2)
    空间复杂度:O(1)
    稳定性:不稳定

    也可以在比较的过程中直接交换,这种在比较过程中就直接交换的类似于冒泡排序,是稳定的。

    function sort2(arr){
        for(let i = 0; i < arr.length-1; i++){
            let min = arr[i]   /*其实可以不用要这个 min 临时变量,直接把 arr[i] 当作 min 就可以*/
            for(let j = i+1; j < arr.length; j++){
                if(arr[j] < min){
                    let temp = arr[j]
                    arr[j] = min
                    min = temp
                }
            }
            arr[i] = min
        }
        return arr
    }
    

    平均时间复杂度:O(n^2), 最好时间复杂度:O(n),最差时间复杂度:O(n^2)
    空间复杂度:O(1)
    稳定性:稳定

  • 相关阅读:
    第一个android App, hello world
    chrome网页重定向
    自动获取MyEcilipse注册名和注册码的方法
    jsp中两种include的区别【转】
    Eclipse中web项目部署至Tomcat【转】
    JAVA EE中session的理解
    JavaBean,POJO,VO,DTO的区别和联系
    Linux下apache+phppgadmin+postgresql安装配置
    Linux下apache+phppgadmin安装配置
    linux下jdk和tomcat的安装配置
  • 原文地址:https://www.cnblogs.com/lovevin/p/13600039.html
Copyright © 2011-2022 走看看