美文网首页@IT·程序猿算法算法世界
排序:选择排序(算法)

排序:选择排序(算法)

作者: Promise_Sun | 来源:发表于2017-07-06 18:03 被阅读185次

文 | 莫若吻


1.简介

排序就是算法。
  选择排序(Selection sort)是一种简单直观的排序算法。

选择排序是不稳定的排序方法。
  eg:序列[9,9, 1]第一次就将第一个[9]与[1]交换,导致第一个9挪动到第二个9后面

Note:一般面试的时候才会用到选择、冒泡排序。

2.原理

选择排序的工作原理是**每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完。 **

3.原理过程图

内循环结束一次,最值出现头角标位置上。(原理过程如下图)

Paste_Image.png

4.时间复杂度

简单选择排序的比较次数与序列的初始排序无关。 假设待排序的序列有 n 个元素,选择排序的赋值操作介于 0 和 3 (n - 1) 次之间; 则比较次数 永远都是n (n- 1) / 2; 而移动次数(即:交换操作)与序列的初始排序有关,介于 0 和 (n - 1) 次之间。当序列正序时,移动次数最少,为 0。当序列反序时,移动次数最多,为n - 1 次;逆序交换n/2次。综上,简单选择排序的时间复杂度为 O(n²)
选择排序的移动次数比冒泡排序少多了,由于交换所需CPU时间比 比较所需的CPU时间多,n值较小时,选择排序比冒泡排序快

5.性能分析 (稳定性)

选择排序的时间复杂度为O(n²),由于每次选择仅考虑某一位置上的数据情况,可能会破坏之前数据的相对位置,因此它是一种不稳定的排序方法。

6.选择排序有两个重要特点:

1)运行时间和输入无关

即不论数组的初始状态的有序程度,选择排序的比较次数都没有变化。考虑到比较次数与元素个数的关系是n (n- 1)/ 2,所以当一个已经比较有序的数组使用选择排序会很不划算。

2)数据的移动操作最少

移动操作次数是一个常量,最多为n-1,其他的算法都不具备这个特征。

7.选择排序与冒泡排序哪个效率更高?

选择排序、冒泡排序都用for(for(if))结构语句。一般选择排序效率会更高一些。
自我总结分析原因:(更详细情况请参考上面选择排序的时间复杂度)
冒泡排序的思想为每一次排序过程,通过相邻元素的交换,将当前没有排好序中的最大(小)移到数组的最右(左)端。而选择排序的思想也很直观:每一次排序过程,我们获取当前没有排好序中的最大(小)的元素和数组最右(左)端的元素交换,循环这个过程即可实现对整个数组排序。
同样数据的情况下,两种算法的循环次数是一样的,但选择排序只有0到1次交换,而冒泡排序只有0到n次交换 。而影响我们算法效率的主要部分是循环和交换,显然,次数越多,效率就越差。选择排序的平均时间复杂度比冒泡排序的稍低。所以相比较而言选择排序效率会更高一些。

8.示例代码(Java)

对给指定数组进行排序:{5,1,6,4,2,8,9}

核心代码:

    /*
    选择排序。
    内循环结束一次,最值出现头角标位置上。
    */
    public static void selectSort(int[] arr)
    {
        for (int x=0; x<arr.length-1 ; x++)
        {
            for(int y=x+1; y<arr.length; y++)
            {
                if(arr[x]>arr[y])          //缺点:性能低。
                {
                     int temp = arr[x];
                     arr[x] = arr[y];
                     arr[y] = temp;
                }
            }
        }
    }```  

__详细代码:__
  (注:大家可以自行运行结果查看)

import java.util.*;
class ArraySort
{
public static void main(String[] args)
{
int[] arr = {5,1,6,4,2,8,9};
//排序前;
printArray(arr);

    //选择排序
    selectSort(arr);

    //冒泡排序
    //bubbleSort(arr);
    
    //排序后:
    printArray(arr);

    //Arrays.sort(arr);  //java中已经定义好的一种排序方式。开发中,对数组排序。要使用该句代码。
}

/*
选择排序。
内循环结束一次,最值出现头角标位置上。
*/
public static void selectSort(int[] arr)
{
    for (int x=0; x<arr.length-1 ; x++)
    {
        for(int y=x+1; y<arr.length; y++)
        {
            if(arr[x]>arr[y])          //缺点:性能低。
            {
                swap(arr,x,y); 
            }
        }
    }
}

/*
无论什么排序。都需要对满足条件的元素进行位置置换。
所以可以把这部分相同的代码提取出来,单独封装成一个函数。
*/
public static void swap(int[] arr,int a,int b)
{
    int temp = arr[a];
    arr[a] = arr[b];
    arr[b] = temp;
}

/*
排序显示格式
*/
public static void printArray(int[] arr)
{
    System.out.print("[");
    for(int x=0; x<arr.length; x++)
    {
        if(x!=arr.length-1)
            System.out.print(arr[x]+", ");
        else
            System.out.println(arr[x]+"]");

    }       
}

}



<br/>
***
版权声明:本文为博主原创文章,转载请必须注明出处,谢谢!
<br/>

相关文章

  • 算法-选择排序

    算 法:选择排序算法时间复杂度: 选择排序算法概述 选择排序伪代码 选择排序实现 选择排序算法概述 排序算法有许...

  • 算法4:插入排序和选择排序算法的比较

    排序算法列表电梯: 选择排序算法:详见 《算法4》2.1 - 选择排序算法(Selection Sort), Py...

  • 图形化排序算法比较:快速排序、插入排序、选择排序、冒泡排序

    图形化排序算法比较:快速排序、插入排序、选择排序、冒泡排序 图形化排序算法比较:快速排序、插入排序、选择排序、冒泡排序

  • PHP常用算法

    基于选择的排序算法 常见的基于选择的排序算法有:冒泡排序、插入排序、选择排序、归并排序和快速排序,我们在选在排序算...

  • 算法and数据结构

    算法 冒泡排序 选择排序 计数排序

  • 基础排序算法总结

    排序算法分为内部排序和外部排序,而我们经常说的基础排序算法,都是内部排序算法。包括冒泡排序,选择排序,插入排序,快...

  • LeetCode大全

    1.常见排序算法: 常见的排序算法:冒泡排序、选择排序、插入排序、归并排序、快速排序、希尔排序、堆排序、计数排序、...

  • 《算法4》2.1 - 插入排序算法(Insertion Sort

    排序算法列表电梯: **选择排序算法:详见 Selection Sort ** 插入排序算法(Insertion ...

  • 排序算法

    排序算法 排序是最基本的算法之一,常见的排序算法有插入排序、希尔排序、选择排序、冒泡排序、堆排序、归并排序及快速排...

  • 面试算法知识梳理(12) - 二叉树算法第二部分

    面试算法代码知识梳理系列 面试算法知识梳理(1) - 排序算法 插入排序 希尔排序 选择排序 冒泡排序 计数排序 ...

网友评论

  • 知识学者:不错,不过冒泡有许多变形😂改进。
    希尔排序,搞不明白😭还有堆排序,快排等
    Promise_Sun:@东风冷雪 希尔排序我有写博客,你可以先看看,不明白的地方可以提出来,我尽量给大家文字讲解清楚。至于你说的是他排序有时间我会写博客的,你可以关注下。这是希尔排序的链接:http://www.jianshu.com/p/d730ae586cf3
  • 编程路上的一只:看到博主的算法功底如此深厚,而算法却是我最薄弱的环节,导致在我制作出函数链后,算法函数一直还没写。

    看到博主算法这么好,想邀请你去函数链写算法函数。

    这样也可以给你带来一些便利:在你写算法博客的时候,可以在函数链提供在线演示运行的例子,加深读者对算法的理解。
    具体情况请看:https://hanshulian.com/nodes?type=recent
  • 你的笑也还算逼真:你有自己的博客或者qq群吗?我是个初学者,文章很好,巩固了我的基础
    Promise_Sun:@你的笑也还算逼真 这是我的博客:http://blog.csdn.net/sun_promise 没精力管理QQ群,所以抱歉。

本文标题:排序:选择排序(算法)

本文链接:https://www.haomeiwen.com/subject/rznhhxtx.html