00:00

00

2019/1/1

选择排序分析

一.选择排序原理

  1.每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置

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

  3.以此类推,直到全部待排序的数据元素排完。 

  选择排序是不稳定的排序方法。例如:序列3,3,2,1, 我们知道第一次遍历的时候,选择最后一个元素1和第一个元素3交换,那么原序列中2个3的相对前后顺序就和之前不一样了,所以选择排序不是一个稳定的排序算法。

二.选择排序时间复杂度

  第一次循环比较 n - 1次,第二次循环比较 n - 2次,依次类推,最后一个元素不需要比较,因此共进行 n - 1次循环,最后一次循环比较1次。

  因此一共比较1 + 2 + 3 + ... +(n - 2)+(n - 1)次,求和得n2/2 - n / 2 ,忽略系数,取最高指数项,该排序的时间复杂度为O(n2)

三.代码实现(Java)

//实现选择排序
public class Test02 {
  public static void main(String[] args) {
      int[] arr = {1,3,2,5,4,9,6};
      selectSort(arr);
      System.out.println(Arrays.toString(arr));
  }
  public static void selectSort(int[] arr){
      if((arr==null)||(arr.length==0)){
          try{
            throw new MyException("出现了数组为空的异常");
        } catch (MyException e) {
            e.printStackTrace();
        }
          return;
      }
      int minIndex = 0;//暂未排序的最小数据的下标
      int temp = 0;//将被交换位置的那个元素
      for(int i = 0 ; i < arr.length ; i++){
          minIndex=i;
          for(int j = i + 1 ; j < arr.length ; j++){//在暂未排序的区域中找到最小数据并保存其下标
              if(arr[j]<arr[minIndex]){//两者中较小的元素的下标赋给minIndex
                  minIndex=j;
              }
          }
          //将最小元素放到本次循环的前端
          temp=arr[i];
          arr[i]=arr[minIndex];
          arr[minIndex]=temp;
      }
  }
}
class MyException extends Exception{
    
    public MyException() {
    }
    public MyException(String msg) {
        super(msg);
    }
}

 测试结果如下

  

 

posted @ 2019-04-08 23:43  认真的杨先森  阅读(844)  评论(0编辑  收藏  举报