zoukankan      html  css  js  c++  java
  • 排序算法——选择排序

    选择排序是排序方法中最简单效率最低的算法

    该方法会遍历(N2)/2:每次抽一位最小数或者最大数放在数组头部。再遍历抽取剩下的数组最小数

    如下所示:

    原数组:9,8,7,6,5,4,3,2,1

    第一轮:1,8,7,6,5,4,3,2,9

    第二轮:1,2,7,6,5,4,3,8,9
    第三轮:1,2,3,6,5,4,7,8,9
    第四轮:1,2,3,4,5,6,7,8,9
    第五轮:1,2,3,4,5,6,7,8,9
    第六轮:1,2,3,4,5,6,7,8,9
    第七轮:1,2,3,4,5,6,7,8,9
    第八轮:1,2,3,4,5,6,7,8,9
    第九轮:1,2,3,4,5,6,7,8,9

    如上图所示这个算法每次都会在红色数字右边选择最小的数字,然后放入红色的位置中去

    效率是(N2)/2。非常简单的效率低的算法。

    代码如下(我写的多了点,以便于后面研究其他算法。java就这么麻烦):

    /**
     * 排序实验的参数
     * @author DHH
     *
     */
    public class DATA implements Comparable  {
        private int i=0;
        
        DATA(int i){
            this.i=i;
        }
        
        public int getI() {
            return i;
        }
    
        public void setI(int i) {
            this.i = i;
        }
    
        @Override
        public int compareTo(Object o) {
        
            return this.i-((DATA)o).getI();
        }
    
        @Override
        public String toString() {
            return "DATA [i=" + i + "]";
        }
        
    }
    /**
     * 用来继承的父类对象
     * @author DHH
     *
     */
    public class Example  {
        /**
         * 为一个数组排序
         * @param a
         */
        public void sort(Comparable[] a){
            
        }
        /**
         * 比较两个数组中的两个值
         * @param a
         * @param i
         * @param j
         * @return
         */
        public int compare(Comparable[] a,int i,int j){
            Comparable m=a[i];
            Comparable n=a[j];
            return m.compareTo(n);
        }
        /**
         * @function 交换数组中的两个下标的位置
         * @param a
         * @param i
         * @param j
         */
        public static void exch(Comparable[] a,int i,int j){
            Comparable m=a[i];
            a[i]=a[j];
            a[j]=m;
        }
    }
    /**
     * 选择排序
     * @author DHH
     *
     */
    public class Select extends Example {
        /**
         * 选择排序的排序代码
         */
        public void sort(Comparable[] a){
            int k;
            for(int i=0;i<a.length;i++){
                k=i;
                for(int j=i;j<a.length;j++){
                    if(a[k].compareTo(a[j])<=0){
                        k=j;
                    }
                }
                exch(a, i, k);
            }
        }
        
        /**
         * 测试方法
         * @param args
         */
        public static void main(String[] args) {
            DATA[] dataArray=new DATA[10];
            dataArray[0]=new DATA(16);
            dataArray[1]=new DATA(6);
            dataArray[2]=new DATA(15);
            dataArray[3]=new DATA(8);
            dataArray[4]=new DATA(11);
            dataArray[5]=new DATA(23);
            dataArray[6]=new DATA(75);
            dataArray[7]=new DATA(4);
            dataArray[8]=new DATA(11);
            dataArray[9]=new DATA(60);
            System.out.println(Arrays.toString(dataArray));
            Select select=new Select();
            select.sort(dataArray);
            System.out.println(Arrays.toString(dataArray));
        }
    
    }

    以上代码输出为两行dataArray。

    第一行为:[DATA [i=16], DATA [i=6], DATA [i=15], DATA [i=8], DATA [i=11], DATA [i=23], DATA [i=75], DATA [i=4], DATA [i=11], DATA [i=60]]

    第二行为:[DATA [i=75], DATA [i=60], DATA [i=23], DATA [i=16], DATA [i=15], DATA [i=11], DATA [i=11], DATA [i=8], DATA [i=6], DATA [i=4]]

    第二行是排序后。

    明天过来写插入排序

  • 相关阅读:
    asmxwebservicebasicauthentication
    asp.net mvc uploading_and_returning_files
    HTTP请求格式 状态码404,404等
    HTTP BASIC 应用(2)
    [转载]HTML生成PDF(c#)
    [转载]ASP.NET MVC的例子中都使用了Repository模式
    spring MVC 如何接收前台传入的JSON对象数组并处理
    表格中的checkbox复选框 全选非全选 公共方法 及提交选中结果
    atitit.提升开发效率MDA 软件开发方式的革命(5)列表查询建模
    atitit.提升开发效率MDA 软件开发方式的革命(3)自动化建表
  • 原文地址:https://www.cnblogs.com/blackdeng/p/8024087.html
Copyright © 2011-2022 走看看