简单选择排序的介绍:

从给定的序列中,按照指定的规则选出某一个元素,再根据规定交换位置后达到有序的目的。

简单选择排序的基本思想:

假定我们的数组为int [] arr = new int[n],第一次我们从arr[0]~arr[n-1]中选择出最小的值与arr[0]交换。第二次我们从arr[1]~arr[n-1]中选择出最小的值与arr[1]交换。第三次我们从arr[2]~arr[n-1]中选择出最小的值与arr[2]交换,...,第i次我们从arr[i-1]~arr[n-1]中选择出最小的值与arr[i-1]交换,...,第n-1次我们从arr[n-2]~arr[n-1]中选择出最小的值与arr[n-2]交换。我们总共进行n-1次的交换,从而得到一个由小到大的排序序列。

简单选择排序的思路详解:

例子:原始的数组:[101,34,119,1]

经过第一次选择排序之后,我们得到的数组:1,[34,119,101]

经过第二次选择排序之后,我们得到的数组:1,34,[119,101]

经过第三次选择排序之后,我们得到的数组:1,34,101,[119]

这个时候,我们的序列已经有序了,并且我们执行的次数一共是是4次(n-1)。

针对上述的例子我们进行说明如下:

(1).选择排序一共有数组大小-1(n-1)轮排序

(2).每一轮排序,又是一个循环,我们先假定每次循环的第一个数都是最小的数,然后和后面的每个数进行比较,如果发现有比当前更小的数,就重新确定这个最小的数,并且要得到这个数的下标。依次进行循环

上述过程在代码中我会通过注释说明。

下面的代码中,我会将选择排序通过两种代码实现:分步骤的实现,整体的实现。在代码中,我们测试的数组是:[101,34,119,1]

(1).分步骤的实现选择排序

public static void main(String[] args) {
// TODO Auto-generated method stub
int[] arr = {101,34,119,1};
selectSort(arr);
} //选择排序
public static void selectSort(int[] arr){
//第一趟排序
System.out.println("执行的第一趟排序:");
//首先我们要假设第一个元素是最小的,并且记录最小元素的下标,这里我们分别用min,minIndex表示。
int min = arr[0];
int minIndex = 0;
for(int j = 1+0;j<arr.length;j++){ //这是第一次的循环,我们要从第二个数开始算起,与第一个数比较。
if(min>arr[j]){ //当我们的min值大于后面的数时,说明min不是最小的,这时候,我们将min与最小的值交换,并且让minIndex索引变成最小值的索引。
min = arr[j];
minIndex = j;
}
}
//通过上面的交换,我们可以得到这趟序列中最小的元素的值。
//因为我们的第一个元素是我们指定的最小元素,因此在找到比第一个元素更小的元素后,我们应该让其与第一个元素交换。
arr[minIndex] = arr[0];
arr[0] = min;
System.out.println(Arrays.toString(arr)); //接下来的几趟排序与第一趟相同
//第二趟排序
System.out.println("执行的第二趟排序:");
min = arr[1];
minIndex = 1;
for(int j = 1+1;j<arr.length;j++){ //j=1+1这个需要注意,因为是第二趟排序,所以应该加1.
if(min > arr[j]){
min = arr[j];
minIndex = j;
}
}
arr[minIndex] = arr[1];
arr[1] = min;
System.out.println(Arrays.toString(arr)); //第三趟排序
System.out.println("执行的第三趟排序:");
min = arr[2];
minIndex = 2;
for(int j = 1+2;j<arr.length;j++){
if(min > arr[j]){
min = arr[j];
minIndex = j;
}
}
arr[minIndex] = arr[2];
arr[2] = min;
System.out.println(Arrays.toString(arr));
}

 上述代码我们得到的最终结果是:

(2).整体的代码实现

	public static void main(String[] args) {
// TODO Auto-generated method stub
int[] arr = {101,34,119,1};
selectSort(arr);
} //选择排序
public static void selectSort(int[] arr){ //选择排序的算法
//通过上面的分步,我们可以知道,可以通过循环嵌套来实现
for(int i=0;i<arr.length-1;i++){ //i代表的就是实现该算法的次数。,具体的解释可以看上述代码
int min = arr[i];
int minIndex = i;
for(int j=i+1;j<arr.length;j++){ //j=i+1这个地方就是代表了,j应该从i+1个位置开始算起,因为之前的已经排好序了~
if(min>arr[j]){
min = arr[j];
minIndex = j;
}
}
arr[minIndex] = arr[i];
arr[i] = min;
System.out.println("第"+(i+1)+"趟排序的结果:");
System.out.println(Arrays.toString(arr)); } }

  上述代码我们得到最终的结果是:

但是,还有一点值得注意的是,观察我们第二趟的结果,我们发现与第一趟的结果是相同的,也就是说,我们在进行选择排序的过程中,可能出现第一个数就是最小的数,这样的话我们可以不需要执行交换的代码,因此选择排序的算法我们可以做进一步的优化,优化代码如下(注释里面有解释):

	public static void main(String[] args) {
// TODO Auto-generated method stub
int[] arr = {101,34,119,1};
selectSort(arr);
} //选择排序
public static void selectSort(int[] arr){ //选择排序的算法
//通过上面的分步,我们可以知道,可以通过循环嵌套来实现
for(int i=0;i<arr.length-1;i++){ //i代表的就是实现该算法的次数。,具体的解释可以看上述代码
int min = arr[i];
int minIndex = i;
for(int j=i+1;j<arr.length;j++){ //j=i+1这个地方就是代表了,j应该从i+1个位置开始算起,因为之前的已经排好序
if(min>arr[j]){
min = arr[j];
minIndex = j;
}
}
if(minIndex != i){ //我们通过比较minIndex与i的值来确定是否 最小值发生了改变,如果没有改变,我们不需要执行下面的代码。
arr[minIndex] = arr[i];
arr[i] = min;
System.out.println("第"+(i+1)+"趟排序的结果:");
System.out.println(Arrays.toString(arr));
} } }

  最终得到的结果如下:

Java数据结构之排序---选择排序的更多相关文章

  1. java数据结构和算法------选择排序

    package iYou.neugle.sort; public class Select_sort { public static void SelectSort(double[] array) { ...

  2. Java基础(46):选择排序的Java封装(完整可运行)

    1 package lsg.ap.select; import java.util.Random; public class SelectSort { //选择排序 /** *@author: 梁山广 ...

  3. Java版冒泡排序和选择排序

    一.理解说明 1.理解和记忆 冒泡排序:依次定位数组元素,每次只和相邻的且符合条件的元素交换位置. 选择排序:依次在数组的每个位置,通过逐个对比选择出最大或最小的元素. 2.知识点说明 (1)数组是引 ...

  4. 数据结构 - 只需选择排序(simple selection sort) 详细说明 和 代码(C++)

    数据结构 - 只需选择排序(simple selection sort) 本文地址: http://blog.csdn.net/caroline_wendy/article/details/28601 ...

  5. java实现冒泡排序,选择排序,插入排序,快速排序(简洁版)及性能测试

    1.冒泡排序是排序里面最简单的了,但性能也最差,数量小的时候还可以,数量一多,是非常慢的. 它的时间复杂度是O(n*n),空间复杂度是O(1) 代码如下,很好理解. public void bubbl ...

  6. Java数据结构与算法之排序

    排序从大体上来讲,做了两件事情: 1.比較两个数据项: 2.交换两个数据项.或复制当中一项 一.冒泡排序 大O表示法:交换次数和比較次数都为O(N*N). 算法原理: 1.比較相邻的元素.假设第一个比 ...

  7. java 冒泡排序法、选择排序

    1.冒泡排序 /* * 冒泡排序 * 外层控制循环多少趟,内层控制每一趟的循环次数 */ public class Test08 { public static void main(String[] ...

  8. 跳跃空间(链表)排序 选择排序(selection sort),插入排序(insertion sort)

    跳跃空间(链表)排序 选择排序(selection sort),插入排序(insertion sort) 选择排序(selection sort) 算法原理:有一筐苹果,先挑出最大的一个放在最后,然后 ...

  9. Java数据结构和算法 - 高级排序

    希尔排序 Q: 什么是希尔排序? A: 希尔排序因计算机科学家Donald L.Shell而得名,他在1959年发现了希尔排序算法. A: 希尔排序基于插入排序,但是增加了一个新的特性,大大地提高了插 ...

随机推荐

  1. [转帖]SSH命令总结

    SSH命令总结 ssh-keygen ssh-copy-id 等命令自己用过 但是知道的不系统 也知道 转发命令 但是也只是知道一点点... ttps://www.cnblogs.com/chenfa ...

  2. jsp运行环境的安装和配置

    1.JDK的安装和配置 1)下载jdk,我下载的是1-jdk-6u26-windows-i586.exe,放在D:\StudySystem\JavaWeb\jdk目录下. 2)安装jdk,直接你下载的 ...

  3. Vue 进阶系列(一)之响应式原理及实现

    Vue 进阶系列(一)之响应式原理及实现:https://juejin.im/post/5bce6a26e51d4579e9711f1d Vue 进阶系列(二)之插件原理及实现:https://jue ...

  4. “laravel.log” could not be opened: failed to open stream

    百度了一下,说是要赋权限,按照操作赋了权限也还是报错,其实只要执行第一个就好,但为了保险起见,我都执行了,还是不行 chmod -R /storage chmod -R /storage/logs c ...

  5. 从入门到自闭之python初识

    Day 01 整型: 对比: 在python 2 版本中有整型,长整型long 在python 3 版本中全部都是整型 用于计算和比较 整型和布尔值的转换 二进制转换成十进制: ​print (int ...

  6. 简单了解 node net 模块

    简单了解 node net 模块 文章记录了对net 模块的简单理解分析. net模块 简单使用 net.Server 类 net.Socket 类 总结 1.1 net模块 Node.js 的 Ne ...

  7. 脚本_通过进程与端口判断myslq服务

    #!bin/bashif [[ $port -eq 1 || $porcess -eq 2 ]];then  #通过条件判断端口和进程执行的返回值.     echo "mysql is s ...

  8. nslookup 工具的使用方法记录

    查询IP地址 nslookup最简单的用法就是查询域名对应的IP地址,包括A记录和CNAME记录,如果查到的是CNAME记录还会返回别名记录的设置情况.其用法是: nslookup 域名 定查询记录类 ...

  9. [易学易懂系列|rustlang语言|零基础|快速入门|(2)|VSCODE配置]

    我们今天来配置下vscode+rust. vscode开发rust很方便.但配置有点坑,我们都认为vscode很简单,很完善. 但这里很多同学也出现不少问题. 我们在这里简单记录下win7下配置的过程 ...

  10. java常用类与包装类--常用类字符串String类、StringBuffer类、Stringbuilder类

    1.String类 1.1String类的概念和储存结构: (1)字符串是一个比较特殊的对象,可以使用new,也可以不使用new来创建字符串对象 String s1 = new String(&quo ...