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

文章目录

选择排序

选择排序:每一次找出数组中最小的元素,并放在对应的索引位置上。一般为两位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,欢迎关注,持续分享。

相关推荐
·白小白几秒前
力扣(LeetCode) ——118.杨辉三角(C++)
c++·算法·leetcode
CoovallyAIHub31 分钟前
超越“识别”:下一代机器视觉如何破解具身智能落地难题?
深度学习·算法·计算机视觉
小白.cpp34 分钟前
list链表容器
数据结构·链表·list
仰泳的熊猫38 分钟前
LeetCode:207. 课程表
数据结构·c++·算法·leetcode
liu****1 小时前
19.map和set的封装
开发语言·数据结构·c++·算法
水冗水孚1 小时前
双指针算法在实际开发中的具体应用之代码Review文章字符串的片段分割
算法·leetcode
DuHz1 小时前
用于汽车雷达应用的步进频率PMCW波形——论文阅读
论文阅读·算法·汽车·信息与通信·信号处理·毫米波雷达
张晓~183399481211 小时前
碰一碰发抖音源码技术搭建部署方案
线性代数·算法·microsoft·矩阵·html5
weixin_448119941 小时前
Datawhale人工智能的数学基础 202510第3次作业
人工智能·算法
CoovallyAIHub1 小时前
全球OCR新标杆!百度0.9B小模型斩获四项SOTA,读懂复杂文档像人一样自然
深度学习·算法·计算机视觉