选题排序(十大排序算法)

文章目录

选择排序

选择排序:每一次找出数组中最小的元素,并放在对应的索引位置上。一般为两位for循环,内层for循环不断的缩减。不稳定,时间复杂度为 O(n²)

两层for循环

java 复制代码
for (int i = 0; i < arr.length; i++) { 

	for (int j = i + 1; j < arr.length; j++) {}

}

详细代码

java 复制代码
/**
 * 作者:Hui
 */

/**
 * 选择排序:每一次找出数组中最小的元素,并放在对应的索引位置上。
 * 一般为两位for循环,内层for循环不断的缩减。
 *
 * @author: Hui
 **/
public class SeletionSort {

    public static void main(String[] args) {
        //初始化数组
        int[] arr = {1, 5, 3, 456, 5, 6, 7, 13, 9, 100};
        System.out.println("排序前:");
        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i]);
        }
        SeletionSort seletionSort = new SeletionSort();
        seletionSort.seletionSortMethod(arr);
        System.out.println("排序后:");
        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i]);
        }
    }

    public int[] seletionSortMethod(int arr[]) {


        int min;

        for (int i = 0; i < arr.length; i++) {

            min = i; //插入的索引位置

            for (int j = i + 1; j < arr.length; j++) {

                if (arr[j] < arr[min]) { //找到比当前值要小的就赋值
                    min = j;
                }
            }
            if (i != min) { //比较完之后继续赋值
                int temp = arr[i];
                arr[i] = arr[min];
                arr[min] = temp;
            }
        }

        return arr;
    }
}

我是小辉,24 届毕业生。当下是找工作ing,欢迎关注,持续分享。

相关推荐
聚客AI1 小时前
🙋‍♀️Transformer训练与推理全流程:从输入处理到输出生成
人工智能·算法·llm
大怪v4 小时前
前端:人工智能?我也会啊!来个花活,😎😎😎“自动驾驶”整起!
前端·javascript·算法
惯导马工6 小时前
【论文导读】ORB-SLAM3:An Accurate Open-Source Library for Visual, Visual-Inertial and
深度学习·算法
骑自行车的码农7 小时前
【React用到的一些算法】游标和栈
算法·react.js
博笙困了8 小时前
AcWing学习——双指针算法
c++·算法
moonlifesudo8 小时前
322:零钱兑换(三种方法)
算法
NAGNIP1 天前
大模型框架性能优化策略:延迟、吞吐量与成本权衡
算法
美团技术团队1 天前
LongCat-Flash:如何使用 SGLang 部署美团 Agentic 模型
人工智能·算法
Fanxt_Ja1 天前
【LeetCode】算法详解#15 ---环形链表II
数据结构·算法·leetcode·链表
侃侃_天下1 天前
最终的信号类
开发语言·c++·算法