[排序算法]选择排序法

目录

1.基本思想

2.冒泡排序的步骤

3.冒泡排序算法的实现

4.时间复杂度分析

5.总结


1.基本思想

选择排序(Selection Sort)是一种简单直观的排序算法,它的基本思想是分多次遍历待排序的序列,每次遍历都找到序列中的最小(或最大)元素,然后将这个元素与序列的当前位置进行交换。这个过程重复进行,直到整个序列被排序完成。

2.冒泡排序的步骤

冒泡排序的具体步骤如下:

  1. 初始化:将序列的第一个元素作为参照点,假设它是最小的。

  2. 寻找最小元素:从序列的第二个元素开始,遍历整个序列,寻找比参照点还小的元素。

  3. 交换:如果找到了比参照点还小的元素,就将它与参照点交换位置。

  4. 移动参照点:将参照点向右移动一位,重复步骤2和3,直到整个序列都被遍历。

  5. 完成排序:当参照点移动到序列的最后一个元素时,整个序列就被排序完成了

3.冒泡排序算法的实现

以下是冒泡排序算法的Java实现示例:

java 复制代码
package com.test.demo;

public class SelectionSortExample {

    public static void main(String[] args) {
        int[] numbers = {64, 34, 25, 12, 22, 11, 90};
        selectionSort(numbers);
        System.out.println("Sorted array: ");
        for (int number : numbers) {
            System.out.print(number + " ");
        }
    }

    public static void selectionSort(int[] array){
        int min ;
        int tmp;
        int length = array.length;
        for (int i=0,len =length-1;i<len;i++){
            min =i;
            //每轮需要比较的次数 N-i
            for (int j=i+1;j<length;j++){
                if(array[min ]>array[j]){
                    // 记录目前能找到的最小值元素的下标
                    min =j;
                }
            }
            // 将找到的最小值和i位置所在的值进行交换
            if(min >i){
                tmp = array[i];
                array[i]=array[min ];
                array[min ]=tmp;
            }
        }
    }
}

4.时间复杂度分析

选择排序的时间复杂度是O(n^2),其中n是序列的长度。这是因为算法需要进行n-1次遍历来找到最小的元素,然后进行n-2次遍历,依此类推,直到最后一次只需要进行一次遍历。

5.总结

选择排序的一个优点是它不涉及复杂的递归调用,因此对于小型数据集或者对于递归深度有限制的环境,它可能是一个不错的选择。然而,对于大型数据集,由于其时间复杂度较高,通常不推荐使用选择排序。

相关推荐
吃好睡好便好7 小时前
用while循环语句求和
开发语言·学习·算法·matlab·信息可视化
王璐WL7 小时前
【C语言入门级教学】函数的概念2
c语言·数据结构·算法
不知名的忻8 小时前
B 树与 B+ 树:面试完全指南
b树·算法·面试·b+树
运筹vivo@9 小时前
2657. 找到两个数组的前缀公共数组 | 难度:中等
算法·leetcode·职场和发展·哈希表
索木木9 小时前
NCCL SHARP 和 TREE算法
java·服务器·算法
心中有国也有家10 小时前
hccl 架构拆解:昇腾集合通信库到底在做什么?
人工智能·经验分享·笔记·分布式·算法·架构
小O的算法实验室11 小时前
2026年MCS,Q-learning增强MOPSO与改进DWA融合算法+复杂三维地形下特定移动机器人动态路径规划
算法
Peter·Pan爱编程12 小时前
10. new_delete 不是 malloc_free 的包装
c++·人工智能·算法
不知名的老吴13 小时前
双栈秒杀表达式的生成方式
数据结构
故事和你9113 小时前
洛谷-【动态规划1】动态规划的引入2
开发语言·数据结构·c++·算法·动态规划·图论