算法之排序算法-选择排序与优化

Posted jiushixihuandaqingtian

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了算法之排序算法-选择排序与优化相关的知识,希望对你有一定的参考价值。

package com.ebiz.sort;

import java.text.SimpleDateFormat;
import java.util.Date;

/**
 * @author YHj
 * @create 2019-07-28 20:58
 * 选择排序
 */
public class Choose 

    public static void main(String[] args) 
        int[] arr = new int[80000];
        for (int i = 0; i < 80000; i++) 
            arr[i] = (int) (Math.random() * 800000);
        



        String s = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
        System.out.println("排序前 = " + s);

        getResult(arr);


        String l = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
        System.out.println("排序后 = " + l);

    



    public static void getResult(int[] arr) 
        for (int i = 0; i < arr.length-1; i++) 
            int min=arr[i]; //假设为最小值
            int minIdex=i;  //最小值的索引
            for (int j = i+1; j <arr.length; j++) 
                if (min>arr[j])
                    //找到最小值以及最小值的位置
                    min=arr[j];
                    minIdex=j;
                
            
            //如果不是一开始的位置不进行交换  优化
            if (minIdex != i) 
                arr[minIdex]=arr[i];
                arr[i]=min;
            
        
    



待完善...

以上是关于算法之排序算法-选择排序与优化的主要内容,如果未能解决你的问题,请参考以下文章

排序算法冒泡选择排序的Python实现及算法优化详解

挖掘算法中的数据结构:O(n^2)排序算法之 选择插入冒泡希尔排序 及 优化

排序算法系列之选择排序

数据结构与算法:十大排序算法之选择排序

数据结构与算法之排序算法:选择排序

面试之选择排序——数组下标越界了吗面试踩坑优化