java数据结构与算法-简单排序-选择排序

一、简介

选择排序的思想其实和冒泡排序有点类似,都是在一次排序后把最小的元素放到最前面。但是过程不同,冒泡排序是通过相邻的比较和交换。而选择排序是通过对整体的选择。举个栗子,对5,3,8,6,4这个无序序列进行简单选择排序,首先要选择5以外的最小数来和5交换,也就是选择3和5交换,一次排序后就变成了3,5,8,6,4.对剩下的序列一次进行选择和交换,最终就会得到一个有序序列。其实选择排序可以看成冒泡排序的优化,因为其目的相同,只是选择排序只有在确定了最小数的前提下才进行交换,大大减少了交换的次数。选择排序的时间复杂度为O(n^2)。

示例图:


二、实现代码如下:

 /**
     * 简单排序-选择排序
     */
    private void sortSimpleSelect(int[] array) {
        int minIndex = 0;
        int size = array.length;
        for (int i = 0; i < size - 1; i++) {//循环比较的数,从左往右走
            minIndex = i;//作为标志记住每次比出来的最小的数位置
            for (int j = i + 1; j < size; j++) {//被比较的数
                if (array[minIndex] > array[j]) {
                    minIndex = j;
                }
            }
            if (minIndex != i) {//如果minIndex!=i说明找到了比i小的数
                swapArray(array, minIndex, i);
            }
        }
        Log.v(TAG, "array值为:" + Arrays.toString(array));
    }
/**
     * 交换俩元素
     * @param array
     * @param m
     * @param n
     */
    private void swapArray(int[] array, int m, int n) {
        int temp = array[m];
        array[m] = array[n];
        array[n] = temp;
    }

调用语句如下:

int[] array=new int[]{3,2,4,1,0,5,7,6,20,15,18,8,12,13,11,9,10,16,17};
sortSimpleSelect(array);


日志打印如下:

08-14 18:04:13.191 5288-5288/com.tool.wpn.quicksort V/MainActivity: array值为:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 15, 16, 17, 18, 20]


源码下载地址:点击打开链接

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值