简单选择排序 -- 思路 与 JAVA代码

简介: 简单选择排序 -- 思路 与 JAVA代码

基本概念

所谓简单选择排序,就是对数组进行n-1次遍历,每次遍历都选择出最大的或最小的将其往前排


举个例子:有一个数组 4,5,3,1,2 将它进行从小到大排序


第一次遍历:找到数组中的最小值 1 ,将它移动到最前面(即和 4 进行交换),此时数组变为: 1,5,3,4,2


第二次遍历:数字 1 已经到了它所应该在的位置,就不用再管它,可以认为将其从数组中“剔除”,遍历从第二个数开始,找出此时最小的数 2 ,将他移动到数组的最前面(即和5进行交换),此时数组变为: 1,2,3,4,5


第三次遍历:照样将数字2从数组中“剔除”,遍历从第三个数开始,找出最小的数字 3,将其移动到数组的最前面(即和自身进行交换,相当于没交换),此时数组还是: 1,2,3,4,5


第四次遍历:照样将数字3从数组中“剔除”,遍历从第四个数开始,找出最小的数字4,将其移动到数组的最前面(即和自身进行交换,相当于没交换),此时数组还是: 1,2,3,4,5


最后得到的就是排好序的数组,无需进行第五次遍历,因为前面四个数排好后,剩下的最后一个位置,自然就是第五个数的位置


算法设计思路

总共需要两层循环,第一层循环控制遍历的次数,从上面的例子可以看出,遍历的次数是数组的长度减一;第二层循环是遍历寻找最小值的过程,从上面的例子可以看出,每次遍历完都要“剔除”一个数,并且这个数在数组最前面,因此,第n次遍历,会从下标n-1开始


JAVA实现

package com.sort;
import java.util.Arrays;
public class SearchSort {
  public static void main(String[] aaa) {
    int[] a=new int[]{5,2,4,3,1,8,6,7};
    sort(a);
    System.out.print(Arrays.toString(a));
  }
  public static void sort(int[] a) {
    //第一层循环,控制遍历次数
    for(int i=0;i<a.length-1;i++)
    {
      //min记录最小的数
      int min=a[i];
      //minNum记录最小的数的下标,用于下面的交换
      int minNum=i;
      //第二层循环,遍历比较出最小值
      for(int j=i+1;j<a.length;j++)
      {
        if(min>a[j])
        {
          min=a[j];
          minNum=j;
        }
      }
      //将最小值移动到最前面
      a[minNum]=a[i];
      a[i]=min;
    }
  }
}
目录
相关文章
|
8天前
|
设计模式 监控 Java
Java多线程基础-11:工厂模式及代码案例之线程池(一)
本文介绍了Java并发框架中的线程池工具,特别是`java.util.concurrent`包中的`Executors`和`ThreadPoolExecutor`类。线程池通过预先创建并管理一组线程,可以提高多线程任务的效率和响应速度,减少线程创建和销毁的开销。
28 2
|
8天前
|
安全 Java
Java多线程基础-10:代码案例之定时器(一)
`Timer` 是 Java 中的一个定时器类,用于在指定延迟后执行指定的任务。它常用于实现定时任务,例如在网络通信中设置超时或定期清理数据。`Timer` 的核心方法是 `schedule()`,它可以安排任务在延迟一段时间后执行。`
29 1
|
1天前
|
Java 测试技术 Web App开发
《手把手教你》系列技巧篇(六十二)-java+ selenium自动化测试-RemoteWebDriver让你的代码与测试分离(远程测试)
【6月更文挑战第3天】本文介绍了在没有本地浏览器的情况下,如何使用RemoteWebDriver进行远程自动化测试。RemoteWebDriver分为客户端和服务端,客户端运行测试代码,服务端启动服务。服务端需要安装JDK、浏览器和对应的WebDriver,并启动selenium-server-standalone.jar。客户端通过URL连接到服务端,并指定预期的浏览器类型。这样,客户端的测试代码就能远程控制服务端的浏览器执行自动化测试。RemoteWebDriver的优点包括跨平台和浏览器测试、提高测试稳定性以及使测试环境和执行代码的机器分离。
17 3
|
4天前
|
存储 并行计算 安全
Java语言编写代码的技术性探讨
Java语言编写代码的技术性探讨
|
4天前
|
安全 Java API
Java语言中的代码安全性探讨
Java语言中的代码安全性探讨
|
6天前
|
Java C++
如何在JAVA代码中嵌入汇编
如何在JAVA代码中嵌入汇编
11 1
|
6天前
|
Java Linux
Linux下如何定位最耗CPU的JAVA代码
Linux下如何定位最耗CPU的JAVA代码
13 0
|
6天前
|
存储 Java 编译器
Java方法的基本内存原理与代码实例
Java方法的基本内存原理与代码实例
13 0
|
7天前
|
存储 Java 调度
Java多线程基础-11:工厂模式及代码案例之线程池(二)
这篇内容介绍了Java多线程基础,特别是线程池中的定时器和拒绝策略。
21 0
|
8天前
|
Java 调度
Java多线程基础-10:代码案例之定时器(二)
Java 多线程基础中,定时器(Timer)的实现通常使用 `PriorityBlockingQueue` 和 `wait/notify` 机制来管理任务。
16 0