数据结构奇妙旅程之深入解析选择排序

选择排序(Selection Sort)是一种简单直观的排序算法。它的工作原理是首先在未排序序列中找到最小(或最大)元素,存放到排序序列的起始位置,然后再从剩余未排序元素中继续寻找最小(或最大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。

以下是选择排序的Java代码实现,并进行详细的代码解析:

java 复制代码
public class SelectionSort {
    public static void main(String[] args) {
        int[] arr = {64, 25, 12, 22, 11};
        selectionSort(arr);
        System.out.println("Sorted array: ");
        printArray(arr);
    }

    static void selectionSort(int arr[]) {
        int n = arr.length;

        // 遍历所有数组元素
        for (int i = 0; i < n-1; i++) {
            // 找到最小元素的索引
            int min_idx = i;
            for (int j = i+1; j < n; j++)
                if (arr[j] < arr[min_idx])
                    min_idx = j;

            // 交换找到的最小元素和第一个元素
            int temp = arr[min_idx];
            arr[min_idx] = arr[i];
            arr[i] = temp;
        }
    }

    /* 打印数组 */
    static void printArray(int arr[]) {
        int n = arr.length;
        for (int i=0; i<n; ++i)
            System.out.print(arr[i] + " ");
        System.out.println();
    }
}

代码解析:

  1. selectionSort 方法是选择排序的主要实现部分。它接受一个整数数组作为参数,并按照升序排序数组。
  2. n 是数组的长度,用于控制循环次数。
  3. 外层循环 for (int i = 0; i < n-1; i++) 遍历数组,每次循环开始时,我们假设当前位置 i 的元素是最小的。
  4. 内层循环 for (int j = i+1; j < n; j++) 用于在剩余未排序的元素中查找最小元素。如果找到一个比当前最小元素更小的元素,我们就更新最小元素的索引 min_idx
  5. 当内层循环结束后,我们找到了从位置 i 到数组末尾的最小元素的索引 min_idx。然后,我们交换位置 imin_idx 的元素。这样,位置 i 上的元素就是到目前为止找到的最小元素。
  6. 当外层循环结束时,整个数组就被排序了。
  7. printArray 方法用于打印数组,用于验证排序结果。

注意:选择排序的时间复杂度为 O(n^2),其中 n 是数组的长度。这意味着对于大数组,选择排序可能不是最高效的排序算法。然而,由于其实现简单且易于理解,选择排序在教学和某些特定场合中仍然很有用。

相关推荐
minhuan10 小时前
大模型应用:不减性能只减负担:大模型稀疏化技术全景与实践.36
大数据·人工智能·算法
爱学大树锯10 小时前
592 · 查找和替换模式
算法
爱学大树锯10 小时前
775 · 回文对
算法
girl-072611 小时前
2025.12.26代码分析
数据结构·算法
大罗辑11 小时前
2026软考备考刷题:软件设计师经典100题(5)含详细解析
算法·软考·软件设计师·2026软考·软设备考
咕噜企业分发小米11 小时前
阿里云Milvus支持哪些向量检索算法?
算法·机器学习·milvus
蒙奇D索大11 小时前
【数据结构】排序算法精讲|折半插入排序全解:高效优化、性能对比、实战剖析
数据结构·学习·考研·算法·排序算法·改行学it
汽车仪器仪表相关领域11 小时前
ZDT-III 通用电机测试系统
数据库·算法·单元测试·压力测试·可用性测试
前端小白在前进11 小时前
力扣刷题:矩阵重叠
算法·leetcode·矩阵
啊阿狸不会拉杆11 小时前
《数字图像处理》-实验1
图像处理·人工智能·算法·计算机视觉·数字图像处理