经典排序算法之-----选择排序(Java实现)

简介: 这篇文章通过Java代码示例详细解释了选择排序算法的实现过程,包括算法的基本思想、核心代码、辅助函数以及测试结果,展示了如何通过选择排序对数组进行升序排列。

其他的经典排序算法链接地址https://blog.csdn.net/weixin_43304253/article/details/121209905

选择排序思想:
思路:

  • 1、从整个数据中挑选出最小的数据放在首位、然后再从剩下的数据中、挑选出最小的数据放在第二位。依次类推
  • 2、首先挑选出整个未排序数据的最小值、放到第一位
  • 3、然后、从第二个位置到最后一个数据中、挑选出最小的值。放在第二位i、依次类推

最关键部分的代码:

for (int i = 0; i < len-1; i++) {
            minIndex=i;//每经过一次循环、下次循环都会减少比较的数据
            //内部循环的主要目的是:找出每一轮中的最小数据下表
            for(int j=i+1;j<len;j++){
                if(arr[minIndex] >arr[j]){
                    minIndex=j;//交换下标、经过一轮的比较、可以找出最小数据的下标
                }
            }
            //外部循环来控制:数据的排序
             int temp =arr[i];//先保存第一个元素的数据
            arr[i] =arr[minIndex];//将每一轮循环后的最小值放在这里
            arr[minIndex] =temp;

        }

在这里插入图片描述

我觉得这个图有助于理解
在这里插入图片描述

然后是代码看一下

package com.zheng.dao;


import java.util.Random;

//选择排序
public class TestChooseDemo {

    /**
     * 思路:从整个数据中挑选出最小的数据放在首位、然后再从剩下的数据中、挑选出最小的数据放在第二位。依次类推
     *      1、首先挑选出整个未排序数据的最小值、放到第一位
     *      2、然后、从第二个位置到最后一个数据中、挑选出最小的值。放在第二位i、依次类推
     */
    public  void sortSelete(int arr[]){
        int len = arr.length;
        int minIndex;//假设最小的数据是第一个

        for (int i = 0; i < len-1; i++) {
            minIndex=i;//每经过一次循环、下次循环都会减少比较的数据
            //内部循环的主要目的是:找出每一轮中的最小数据下表
            for(int j=i+1;j<len;j++){
                if(arr[minIndex] >arr[j]){
                    minIndex=j;//交换下标、经过一轮的比较、可以找出最小数据的下标
                }
            }
            //外部循环来控制:数据的排序
             int temp =arr[i];//先保存第一个元素的数据
            arr[i] =arr[minIndex];//将每一轮循环后的最小值放在这里
            arr[minIndex] =temp;

        }


    }

    //随机生成一个数组
        public int[] randomArr(int len,int maxNum,int minNum){
        int []arr=new int[len];//定义一个一维数组
        Random random = new Random();
        for (int i = 0; i < len; i++) {
            arr[i]=random.nextInt(maxNum-minNum+1)+minNum;
        }
        return arr;
    }

    //打印数组
    public void Print(int[] arr){
        int len =arr.length;
        System.out.print("【");
        for (int i = 0; i < len; i++) {
            if(i==len-1){
                System.out.print(arr[i]);
            }else{
                System.out.print(arr[i]+"、");
            }
        }
        System.out.println("】");
    }

    public static void main(String[] args) {
        TestChooseDemo testChooseDemo = new TestChooseDemo();
//        int[] arr={1,3,2,6,4,5,8,7,9};
//        System.out.print("原始数据:");
//        testChooseDemo.Print(arr);
//        System.out.print("选择排序后的数据:");
//        testChooseDemo.sortSelete(arr);
//        testChooseDemo.Print(arr);

        //生成一个随机数组
         int []arr =  testChooseDemo.randomArr(10,100,50);
        System.out.print("生成的随机数组:");
          testChooseDemo.Print(arr);
        System.out.print("选择排序后数据:");
          testChooseDemo.sortSelete(arr);
          testChooseDemo.Print(arr);



    }
}

测试1:
在这里插入图片描述
测试2:
在这里插入图片描述
测试3:
在这里插入图片描述

相关文章
|
8天前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
34 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
11天前
|
算法 搜索推荐
数据结构与算法学习十一:冒泡排序、选择排序、插入排序
本文介绍了冒泡排序、选择排序和插入排序三种基础排序算法的原理、实现代码和测试结果。
12 0
数据结构与算法学习十一:冒泡排序、选择排序、插入排序
|
13天前
|
算法 Java 数据中心
探讨面试常见问题雪花算法、时钟回拨问题,java中优雅的实现方式
【10月更文挑战第2天】在大数据量系统中,分布式ID生成是一个关键问题。为了保证在分布式环境下生成的ID唯一、有序且高效,业界提出了多种解决方案,其中雪花算法(Snowflake Algorithm)是一种广泛应用的分布式ID生成算法。本文将详细介绍雪花算法的原理、实现及其处理时钟回拨问题的方法,并提供Java代码示例。
33 2
|
18天前
|
搜索推荐 Java Go
深入了解选择排序算法
深入了解选择排序算法
15 4
|
15天前
|
搜索推荐 算法
【排序算法(一)】——插入排序,选择排序 —> 深层解析
【排序算法(一)】——插入排序,选择排序 —> 深层解析
|
17天前
|
算法 Python
Python算法编程:冒泡排序、选择排序、快速排序
Python算法编程:冒泡排序、选择排序、快速排序
16 0
|
2月前
|
算法 Java
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
47 6
|
2月前
|
搜索推荐 算法 Java
|
2月前
|
存储 算法 Java
LeetCode经典算法题:打家劫舍java详解
LeetCode经典算法题:打家劫舍java详解
63 2
|
2月前
|
人工智能 算法 Java
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
46 1