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

文章目录

选择排序

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

相关推荐
前端小白在前进43 分钟前
力扣刷题:复原IP地址
tcp/ip·算法·leetcode
yaoh.wang1 小时前
力扣(LeetCode) 94: 二叉树的中序遍历 - 解法思路
python·算法·leetcode·面试·职场和发展·二叉树·跳槽
Evand J1 小时前
【课题推荐】基于视觉(像素坐标)与 IMU 的目标/自身运动估计(Visual-Inertial Odometry, VIO),课题介绍与算法示例
人工智能·算法·计算机视觉
xu_yule1 小时前
算法基础(背包问题)—分组背包和混合背包
c++·算法·动态规划·分组背包·混合背包
蓝色汪洋1 小时前
数码串和oj
数据结构·算法
努力学算法的蒟蒻1 小时前
day39(12.20)——leetcode面试经典150
算法·leetcode·面试
科学最TOP1 小时前
xLSTM-Mixer:基于记忆混合的多变量时间序列预测
大数据·人工智能·算法·机器学习·时间序列
xlq223222 小时前
29.哈希(下)
算法·哈希算法·散列表
阿昭L2 小时前
leetcode链表是否有环
算法·leetcode·链表
yaoh.wang2 小时前
力扣(LeetCode) 83: 删除排序链表中的重复元素 - 解法思路
程序人生·算法·leetcode·链表·面试·职场和发展