Java算法:选择排序

一、选择排序

选择排序(Selection sort)是一种简单直观的 排序算法

工作原理:第一次从待排序的 数据元素 中选出最小(或最大)的一个元素,存放在序列的起始位置,然后再从剩余的未排序元素中寻找到最小(大)元素,然后放到已排序的序列的末尾。以此类推,直到全部待排序的数据元素的个数为零。选择 排序 是不稳定的排序方法。

二、选择排序步骤

1、首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置。

2、再从剩余未排序元素中继续寻找最小(大)元素,然后放到未排序序列的起始位置。

3、重复第二步,直到所有元素均排序完毕。

三、java实现选择排序

java 复制代码
   public static void main(String[] args) {

        //数组数据
        Integer[] arr = getData();
        System.out.println(Arrays.toString(arr));

        //选择排序
        selectSort(arr);
        System.out.println(Arrays.toString(arr));
    }

    /**
     * 数组进行排序
     *
     * @param arr
     * @return
     */
    private static Integer[] selectSort(Integer[] arr) {
        //循环
        for (int i = 0; i < arr.length; i++) {
            //默认第一个最小值
            int min = arr[i];
            //默认第一个最小值索引
            int min_index = i;
            //循环比较
            for (int j = i + 1; j < arr.length; j++) {
                //比较找出最小值
                if (arr[j] < min) {
                    min = arr[j]; //最小值
                    min_index = j; //对应索引
                }
            }
 
            //判断最小索引不等于i索引,就交换值;
            if (min_index != i) {
                arr[min_index] = arr[i]; //将查找到最小值与第i个值交换位置
                arr[i] = min; //将最小值赋给对应的位置
            }

        }
        return arr;

    }

    /**
     * (1) 生成1-100范围的随机数20个
     */
    private static Integer[] getData() {
        Set<Integer> sets = new HashSet<>();
        Random random = new Random();
        while (true) {
            //生成1-100的随机数
            int ran = random.nextInt(100) + 1;
            //添加
            sets.add(ran);
            //判断生成20个数据
            if (sets.size() >= 20) {
                break;
            }
        }
        // 将Set转换成数组
        Integer[] arr = sets.toArray(new Integer[sets.size()]);
        return arr;
    }

效果:

四、性能分析

时间复杂度 :
最好最差情况,选择排序的数据之间的比较次数都是固定的,
而最好情况:数组有序时,需要交换0次,最坏情况:数组无序时,交换n-1次
总体的排序时间是比较+交换的总和,所以时间复杂度为O(N^2)

选择排序理解和实现起来都比较简单,但效率比较低,一般很少使用选择排序

👉空间复杂度 :
没有额外空间的开销,只有常数个记录的辅助空间,空间复杂度为O(1)

相关推荐
寻星探路29 分钟前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
你撅嘴真丑3 小时前
第九章-数字三角形
算法
曹牧3 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
uesowys3 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
ValhallaCoder3 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮3 小时前
AI 视觉连载1:像素
算法
爬山算法4 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
智驱力人工智能4 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
kfyty7254 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎4 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven