【笔记15】排序算法:选择排序和堆排序

简介: Java实现选择排序算法

一、选择排序(Selection Sort)思想

在这里插入图片描述

① 从序列中找出最大的那个元素与最末尾的元素交换位置(执行完一轮后,最末尾的那个元素是最大的元素)
② 忽略 ① 中找到的最大元素,重复执行步骤 ①

n - 1 次最大的元素(n 是元素个数)

二、代码实现

    public static void selectionSort(Integer[] ints) {
        // 找最大的元素与最末尾的交换位置
        for (int end = ints.length - 1; end > 0; end--) {
            int maxNumIdx = 0; // 假设第一个位置的元素就是整个序列中最大的
            for (int start = 1; start <= end; start++) { // 一趟选择排序(已经选出了一个最大的元素)
                if (ints[start] > ints[maxNumIdx]) {
                    maxNumIdx = start;
                }
            }
            // 把最大的元素和最末尾的元素交换
            int temp;
            temp = ints[maxNumIdx];
            ints[maxNumIdx] = ints[end];
            ints[end] = temp;
        }
    }

三、问题讨论

选择排序的交换次数要远远少于冒泡排序,平均性能优于冒泡排序。

一趟选择排序是在选择一个最大的元素(选最值

选最值可通过【堆】进行优化

相关文章
|
2月前
|
算法
【❤️算法笔记❤️】-每日一刷-19、删除链表的倒数第 N个结点
【❤️算法笔记❤️】-每日一刷-19、删除链表的倒数第 N个结点
69 1
|
2月前
|
算法 索引
❤️算法笔记❤️-(每日一刷-141、环形链表)
❤️算法笔记❤️-(每日一刷-141、环形链表)
50 0
|
2月前
|
算法
【❤️算法笔记❤️】-(每日一刷-876、单链表的中点)
【❤️算法笔记❤️】-(每日一刷-876、单链表的中点)
44 0
|
2月前
|
算法
【❤️算法笔记❤️】-每日一刷-23、合并 K 个升序链表
【❤️算法笔记❤️】-每日一刷-23、合并 K 个升序链表
32 0
|
2月前
|
存储 算法
【❤️算法笔记❤️】-每日一刷-21、合并两个有序链表
【❤️算法笔记❤️】-每日一刷-21、合并两个有序链表
102 0
|
2月前
|
算法 API 计算机视觉
人脸识别笔记(一):通过yuface调包(参数量54K更快更小更准的算法) 来实现人脸识别
本文介绍了YuNet系列人脸检测算法的优化和使用,包括YuNet-s和YuNet-n,以及通过yuface库和onnx在不同场景下实现人脸检测的方法。
63 1
|
2月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
70 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
2月前
|
算法
❤️算法笔记❤️-(每日一刷-160、相交链表)
❤️算法笔记❤️-(每日一刷-160、相交链表)
18 1
|
2月前
|
算法 搜索推荐
数据结构与算法学习十八:堆排序
这篇文章介绍了堆排序是一种通过构建堆数据结构来实现的高效排序算法,具有平均和最坏时间复杂度为O(nlogn)的特点。
74 0
数据结构与算法学习十八:堆排序
|
2月前
|
算法 搜索推荐
数据结构与算法学习十一:冒泡排序、选择排序、插入排序
本文介绍了冒泡排序、选择排序和插入排序三种基础排序算法的原理、实现代码和测试结果。
21 0
数据结构与算法学习十一:冒泡排序、选择排序、插入排序