java实现选择排序

算法步骤

  • 首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置
  • 再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。
  • 重复第二步,直到所有元素均排序完毕。

动图演示:

以下是Java实现选择排序的代码:

java 复制代码
public class SelectionSort {
    public static void selectionSort(int[] arr) {
        int n = arr.length;

        // 遍历未排序部分的元素
        for (int i = 0; i < n - 1; i++) {
            // 假设未排序部分的第一个元素是最小值
            int minIndex = i;
            // 在未排序部分寻找最小值
            for (int j = i + 1; j < n; j++) {
                if (arr[j] < arr[minIndex]) {
                    minIndex = j;
                }
            }
            // 如果未排序部分的第一个元素不是最小值,交换它们
            if (minIndex != i) {
                int temp = arr[i];
                arr[i] = arr[minIndex];
                arr[minIndex] = temp;
            }
        }
    }

    public static void main(String[] args) {
        int[] arr = {5, 2, 8, 1, 9, 4, 6, 3, 7};
        selectionSort(arr);
        for (int i : arr) {
            System.out.print(i + " ");
        }
    }
}

输出:

复制代码
1 2 3 4 5 6 7 8 9
相关推荐
老鼠只爱大米几秒前
LeetCode经典算法面试题 #104:二叉树的最大深度(深度优先搜索、广度优先搜索等多种实现方案详细解析)
算法·leetcode·二叉树·dfs·bfs·深度优先搜索·广度优先搜索
疯狂的喵2 分钟前
分布式系统监控工具
开发语言·c++·算法
爱尔兰极光4 分钟前
LeetCode热题100--两数之和
算法·leetcode·职场和发展
2301_822382767 分钟前
模板编译期排序算法
开发语言·c++·算法
m0_5613596712 分钟前
嵌入式C++调试技术
开发语言·c++·算法
yuan1999716 分钟前
高光谱遥感图像异常检测KRX算法Matlab实现
算法·机器学习·matlab
努力学习的小廉17 分钟前
我爱学算法之—— 回溯
算法·深度优先
2301_7634724617 分钟前
C++中的享元模式高级应用
开发语言·c++·算法
weixin_4589232019 分钟前
分布式日志系统实现
开发语言·c++·算法
我是咸鱼不闲呀23 分钟前
力扣Hot100系列15(Java)——[二叉树]总结(有效的括号,最小栈,字符串解码,每日温度,柱状图中最大的矩形)
java·算法·leetcode