美文网首页数据结构和算法分析计算机杂谈
【算法】排序(一)选择排序

【算法】排序(一)选择排序

作者: 胖若两人_ | 来源:发表于2017-11-15 07:54 被阅读0次
Google Image

在排序算法中,最简单的莫过于选择排序了。


本文将介绍以下内容

排序思路
算法实现(JAVA)
测试阶段
算法分析

排序思路:

在选择排序算法中分别有一个外循环和一个内循环,假设需要排序的序列共有n个元素,所以外循环的次数为n次,在n次交换(外循环)中,每次设置序列中的第一个元素为最小值(min),然后进行内循环,每次内循环都将序列中与min比较,若有元素小于min,则进行交换(若没有,min自己与自己交换)。所以内循环的次数暂时不确定。

简而言之,就是在未排序的序列中,每次选取序列首位元素,依次与序列中其他元素比较,进而交换元素,达到排序的效果。

算法实现

1.外循环

      public static void selectionSort(int[] a){
          int n = a.length;
          for (int i = 0; i < n; i++) {                      //外循环共n次
              int min = i;
              int temp = a[i];                               //
              a[i] = a[min];                                 // 交换元素
              a[min] = temp;                                 //
          } 
      } 

共有n次交换

2.内循环(比较大小并交换元素索引)

        for (int j = i + 1; j < n; j++) {
                 if(a[j] < a[min]){
                    min = j;                 //如果由元素小于min,则交换元素索引
                }
        }

j = i + 1, i +2 , i + 3 ... n.
共有n - i - 1次比较,比较的次数将会在下文提及。

3.交换元素

        int temp = a[i];
        a[i] = a[min];
        a[min] = temp;

所以,选择排序的代码块

就是如此了:

public static void selectionSort(int[] a){
        int n = a.length;
        for (int i = 0; i < n; i++) {
            int min = i;
            for (int j = i + 1; j < n; j++) {
                if(a[j] < a[min]){
                    min = j;
                }
            }
            int temp = a[i];
            a[i] = a[min];
            a[min] = temp;
        } 
    }

测试阶段

我们来写一个测试数据:

public static void main(String[] args){
        int[] a = new int[10];
        for (int i = 0; i < a.length; i++) {
            a[i] = (int)(Math.random()*100);      //随机输入测试数据
            System.out.print(a[i] + " ");
        }
        System.out.println();
        selectionSort(a);
        for (int i = 0; i < a.length; i++) {
            System.out.print(a[i] + " ");
        }
    }

随机选取几组排序结果:


test 1 test 2 test 3

算法分析:

1. 特点
  1. 运行时间与输入数据无关,运行时间与数组大小成线性相关,无论
    初始数据的有序性如何,都不会改变元素交换的次数。

  2. 数据的移动最少,这是其他排序所不能比的,每次外循环使数据移
    动一次,所以选择排序的数据移动次数为 n 次。

2. 时间复杂度
  • 内循环:n 次交换

  • 外循环:比较的次数随着i的增长而减少,每次内循环有n -1 - i 次比
    较,总共比较次数:
    (n - 1) + (n - 2) + ... + 2 + 1 = n(n - 1) / 2

  • 基本操作总数: n + n(n - 1) /2 = n(n + 1) / 2 ~ n2/2

  • 所以,时间复杂度为O(n2),平方级别

3. 空间复杂度
  • 在交换素组元素时,需要建立一个临时变量来帮助交换元素,所以空间复杂度为O(1)
4. 稳定性
  • 由于选择排序在排序前后会打乱相同键值元素的相对顺序,所以选择排序是不稳定的

关于选择排序的说明就到这里了,下一篇将会是 冒泡排序

给颗红心,举手之劳, 谢谢!

相关文章

  • 算法-选择排序

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

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

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

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

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

  • PHP常用算法

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

  • 排序算法

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

  • 算法and数据结构

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

  • 常用排序算法总结

    一、选择排序 选择排序示意图 选择排序(Selection sort)也是一种简单直观的排序算法。 算法步骤: 1...

  • 选择排序算法

    一、选择排序算法 选择排序(Selection sort)是一种简单直观的排序算法。 二、算法思想 每一次从待排序...

  • 排序算法(四)选择排序

    排序算法(四)选择排序 1.算法思路  选择排序(Selection-Sort)是一种简单直观的排序算法。它的工作...

  • JAVA数据结构和算法——简单排序

    冒泡排序 选择排序 插入排序 排序算法的选择 除非手边没有算法书可参考,一般情况几乎不太用冒泡排序。选择排序虽然把...

网友评论

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

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