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


    • 实现思路:

      1.依次从数组或者队列的开头取出第一个数,第二个,第n个和后面的数进行比较。

      2.把每次比较得到的最大值或者最小值放在数组的最前面。

    • 动图演示:

    • 代码实现:

    package 排序;
    
    import java.text.SimpleDateFormat;
    import java.util.Date;
    
    public class Select_Sort {
        public static void main(String[] args){
            //打印排序之前的时间
            SimpleDateFormat time = new SimpleDateFormat("yyyy:MM:dd:HH:mm:ss");
            System.out.println(time.format(new Date()));
            
    		//设置这么多的数组和值是为了测试性能,80000个数据大概花了12秒左右
            //后面试了一下80十万个数据,结果等了很久都没有结果就没试了
            int[] arr = new int[80000];
            for (int index = 0; index < 80000; index++) {
                arr[index] = (int)(Math.random() * 80000);
            }
    
            int max = 0;
            for (int i = 0; i < arr.length-1; i++) {
                for(int j = i; j < arr.length-1; j++){
                    if (arr[i] > arr[j+1]){
                        max = arr[i];
                        arr[i] = arr[j+1];
                        arr[j+1] = max;
                    }
                }
            }
    		System.out.println(Arrays.toString(arr));
            //打印排序之后的时间
            SimpleDateFormat time2 = new SimpleDateFormat("yyyy:MM:dd:HH:mm:ss");
            System.out.println(time2.format(new Date()));
        }
    }
    
    
    • 算法分析:

      每次循环得到一个极值,每次循环需要比较n-1,n-2.....1次,共循环n-1次。这样时间复杂度为:

        T(n) =  (1+n-1)*(n-1)/2 = n*(n-1)/2 = (n^2 - n)/2
        O(n) = O(f(n)) = O(n^2)
      

      由于该算法没有太大的优化空间,所以总的执行次数和时间复杂度是固定的,且属于不稳定的排序算法。

  • 相关阅读:
    docker.service启动失败:Unit not found
    本地测试环境搭建
    2016 年总结
    node-http-proxy修改响应结果
    JavaScript那些事儿(01): 对象
    Javascript正则表达式
    addEventListener之handleEvent
    《CSS那些事儿》读书笔记
    《编写高质量代码--Web前端开发修炼之道》读书笔记
    Javascript闭包简单理解
  • 原文地址:https://www.cnblogs.com/coding-996/p/12273256.html
Copyright © 2011-2022 走看看