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

文章目录

选择排序

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

相关推荐
weixin_307779131 小时前
使用Python高效读取ZIP压缩文件中的UTF-8 JSON数据到Pandas和PySpark DataFrame
开发语言·python·算法·自动化·json
柳安忆1 小时前
【论文阅读】Sparks of Science
算法
web安全工具库1 小时前
从课堂笔记到实践:深入理解Linux C函数库的奥秘
java·数据库·算法
周杰伦_Jay2 小时前
【Java集合体系】全面解析:架构、原理与实战选型
java·开发语言·数据结构·链表·架构
爱编程的鱼3 小时前
C# 变量详解:从基础概念到高级应用
java·算法·c#
tkevinjd3 小时前
反转链表及其应用(力扣2130)
数据结构·leetcode·链表
HalvmånEver3 小时前
红黑树实现与原理剖析(上篇):核心规则与插入平衡逻辑
数据结构·c++·学习·算法·红黑树
哆啦刘小洋4 小时前
T:堆的基本介绍
算法
AresXue4 小时前
你是否也在寻找二进制和字符串的高效转换算法?
算法
Swift社区4 小时前
从 0 到 1 构建一个完整的 AGUI 前端项目的流程在 ESP32 上运行
前端·算法·职场和发展