选择排序Java实现

排序原理:

        1.第一次遍历的过程,都假定第一个选择的元素是最小的值,和其他索引的值进行比较,如果第一个元素索引处的值大于X处索引值的时候,则认定X处的值为最小值,则交换两处的索引号码(现在最小值的索引就是X),第一次遍历结束就会找到最小值的索引。

        2.交换第一次个索引与最小值所在索引处的值

        3.循环即可,直到排完序

代码实现

import java.util.Arrays;

public class Selection {
        /*
           对数组a中的元素进行排序
        */
        public static void sort(Comparable[] a){
            for(int i = 0;i<=a.length-2;i++){
                //定义一个变量,记录最小元素所在的索引,默认为参与选择排序的第一个元素所在位置
                int mainIndex = i;
                for (int j = i+1;j<a.length;j++){
                    //需要比较最小索引maiIndex处的值与j索引处的值;
                    if(greater(a[mainIndex],a[j])){
                        mainIndex = j;
                    }
                }
                //交换最小元素所在索引minIndex处的值与索引处的值
                exch(a,i,mainIndex);
            }
        }


        /*
            比较v元素是否大于w元素
         */
        private static  boolean greater(Comparable v,Comparable w){
            return v.compareTo(w)>0;
        }


        /*
        数组元素i和j交换位置
         */
        private static void exch(Comparable[] a,int i,int j){
            Comparable temp;
            temp = a[i];
            a[i]=a[j];
            a[j]=temp;
        }

        public static void main(String[] args) {
            //原始数据
            Integer[] a = {4,6,8,7,9,2,10,1};
            Selection.sort(a);  //把数组a传给 sort方法   因为是static修饰 可以直接类名+方法名称调用
            System.out.println(Arrays.toString(a));//{1,2,4,5,7,8,9,10}
        }
}

 需要注意的是:

在greater方法中compareTo是比较两个数大小的方法;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值