美文网首页Android_Speak
排序算法选择排序

排序算法选择排序

作者: GB_speak | 来源:发表于2017-04-18 13:55 被阅读14次

简单选择排序(Simple Selection Sort)
就是通过n-i次关键字的比较,从n-i+1个记录中选出关键字最小的记录,并和第i(1<=i<=n)个记录交换之

时间复杂度:

1) 最好情况:本身有序,需要比较n-1次 时间复杂度为o(n)

2)最坏情况:逆序情况,需要比较(n-1)+(n-2)+…+2+1=n(n-1)/2 时间复杂度为o(n²)
性能上略优于冒泡排序 减少了交换次数

static void selectionSort(int[] array) {  
        if (array != null && array.length > 0) {  
            int i, j,min;  
            for (i = 0; i < array.length; i++) {  
                min=i;  
                for (j = i + 1; j < array.length; j++) {  
                    if (array[min] > array[j]) {  
                        min=j;//找出最小记录  
                    }  
                }  
                if(i!=min){//如果最小记录位置有变化,执行交换  
                    swap(array, i, min);  
                }  
            }  
        }  
    }```

/**

  • 将数组的2个位置交换
    */
    static void swap(int[] array, int i, int j) {
    if (array != null && array.length > 0) {
    if (i >= 0 && j >= 0 && i <= array.length && j <= array.length) {
    int temp = array[i];
    array[i] = array[j];
    array[j] = temp;
    }
    }
    }```

相关文章

  • 算法-选择排序

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

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

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

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

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

  • PHP常用算法

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

  • 算法and数据结构

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

  • 基础排序算法总结

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

  • LeetCode大全

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

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

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

  • 排序算法

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

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

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

网友评论

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

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