数据结构 排序 java_Java数据结构之排序---选择排序

简单选择排序的介绍:

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

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

假定我们的数组为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

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

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

if(min > arr[j]){

min = arr[j];

minIndex = j;

}

}

arr[minIndex] = arr[2];

arr[2] = min;

System.out.println(Arrays.toString(arr));

}

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

799e978f702746f13a313513e2204d54.png

(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

int min = arr[i];

int minIndex = i;

for(int j=i+1;j

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));

}

}

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

5a88d528bc4a145b017c77b664874413.png

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

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

int min = arr[i];

int minIndex = i;

for(int j=i+1;j

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));

}

}

}

最终得到的结果如下:

98cf329174762065b347e1b8b11f26b7.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/558077.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php和java 2017_Php与java的区别

Php与java的区别1.java和php技术层面对比:java是纯面向对象开发,功能强大,分支众多,没有java不能做的软件,PHP有他独特的领域,那就是WEB在这方面没有可以和他相比较,其与java相比较之下在这一方面基本上完胜java因其专注的领域不同所以没有太大可比性,PHP适合于快速开发,中小型…

python百度aip移动目标监控系统_python利用百度云接口实现车牌识别

一个小需求---实现车牌识别。目前有两个想法调云在线的接口或者使用SDK做开发(配置环境和编译第三方库很麻烦,当然使用python可以避免这些问题)自己实现车牌识别算法(复杂)!一开始准备使用百度云文字识别C SDK来做,发现需要准备curl、jsoncpp…

centos tar安装mysql_centos系统通过tar.gz包安装mysql5.7.19

系统:centos6.5 64位系统1、下载mysql本人选的linux generic 通用版 64位2、把mysql传到服务器并解压到/usr/localtar -xzvf mysql-5.7.19-linux-glibc2.12-x86_64.tar -C /usr/local3、进入/usr/local目录:cd /usr/local4、为mysql安装目录创建软链接ln -s mysq…

java6打印机不能用_高分求解:java中调用的打印机在什么情况下不可用?

java文档中说PrinterJob类中的getPrinterJob()方法无论返回的打印机是否可用都不会返回一个null值。我查阅过一些文献有介绍说可以用getPrintService()方法测试返回的数值是否为null来...java文档中说PrinterJob类中的getPrinterJob()方法无论返回的打印机是否可用都不会返回一…

java中算两个时间内的秒数_java – Joda Time – 计算两个日期之间的秒数会引发异常....

我使用以下代码来计算两个日期之间的秒数差异:long secondsBetween (Seconds.secondsBetween(new LocalDate("1901-01-01"), new LocalDate()).getSeconds());但是我得到以下异常:08-08 18:21:27.345: E/AndroidRuntime(6972): java.lang.Run…

java快速排序从小到大_JAVA一个快速排序实现代码

首先排序的方法有很多种:插入排序,冒泡排序,堆排序,归并排序,选择排序,计数排序,基数排序,桶排序,快速排序等这里是主要讲解一下快速排序这个方法,我也是看了…

java 反射 内存_Java 反射

Java 反射正常的类加载过程当执行new xxx();语句时,JVM会被触发加载.class文件JVM从本地文件找到class文件并且加载到内存中JVM自动创建一个class对象 (一个类只产生一个class对象)将Java的二进制代码合并到JVM的运行状态之中验证: 确保类的信息符合JVM规…

java取json对象的值_java的JsonObject对象提取值方法

实例如下所示:import com.alibaba.fastjson.JSON;import com.alibaba.fastjson.JSONArray;import com.alibaba.fastjson.JSONObject;import io.swagger.models.auth.In;import java.io.IOException;import java.security.KeyManagementException;import java.securi…

aqs clh java_【Java并发编程实战】----- AQS(一):简介

在前面博客中,LZ讲到了ReentrantLock、ReentrantReadWriteLock、Semaphore、CountDownLatch,他们都有各自获取锁的方法,同时相对于Java的内置锁,他们具有明显的优势:花最小的空间开销创建锁、最少的时间开销获得锁、使…

为什么数据结构不用java_泛谈Java中的不可变数据结构

作为我最近一直在进行的一些编码访谈的一部分,有时会出现不变性问题。我自己并不过分教条,但每当不需要可变状态时,我会试图摆脱导致可变性的代码,这在数据结构中通常是最明显的。然而,似乎对不可变性的概念存在一些误…

java后台解析json并保存到数据库_[Java教程]ajax 发送json 后台接收 遍历保存进数据库...

[Java教程]ajax 发送json 后台接收 遍历保存进数据库0 2017-09-25 15:00:23前台怎么拿参数的我就不管了我也不会反正用这个ajax没错ajax 代码 一定要写明http请求类型 {contentType:"application/x-www-form-urlencoded; charsetutf-8",}这一段很重要(就是因为这个…

java实时更新权限_java – 如何使用Spring Security重新加载用户更新的权限

如果您需要动态更新登录的用户权限(当这些权限发生变化时,无论什么原因),无需登出并登录,您只需要重置Spring SecurityContextHolder中的Authentication对象(安全令牌)即可.例:Authentication auth SecurityContextHolder.getContext().getAuthentication();List u…

gitlab ci 配置 java_GitLab CI/CD 配置

GitLab CI/CD 配置概念操作示例创建测试项目 sample-web,然后打开项目的 Runners 配置找到这个地方,后边要用然后搭建 gitlab-runner,CI/CD 需要通过它实现# 创建 gitlab-runner 目录mkdir -p /usr/local/gitlab-runner && cd /usr/l…

mysql的dbconn_管道错误使用mysql.conn

我完全迷路了。这是我的管道。我说我跑错了File "c:\python27\lib\site-packages\twisted\internet\defer.py", line 588, in _runCallbackscurrent.result callback(current.result, *args, **kw)File "C:\Python27\bff\bff\pipelines.py", line 42, in …

java失败javac成功_JAVA SE JDK-10安装、配置(解决java成功,javac失败问题)

本文是在win10环境下安装JDK-10在linux环境下安装JDK-10请点击:CentOS 7 安装、配置JDK-101、下载JDK包点击打开下载网站点击图中的Accept License Agreement,再选择Win版本进行下载2、安装JDK包下载完毕,运行安装程序修改安装路径(这里选择的…

java搭建聊天服务器_使用 ServerSocket 建立聊天服务器-2

1.从serverListener中可以看出,每一个客户端创建新的请求之后,都会把它分配给一个独立的chatsocket ,但是每一个ChatSocket都是相互独立的,他们之间并不能沟通,所以要新建一个类,将这些新建的线程管理起来,然后实现他们之间的相互通信.(类似于微信加群聊天的功能)由于一个聊天服…

java实验10流_实验9 Java输入输出流

《实验9 Java输入输出流》由会员分享,可在线阅读,更多相关《实验9 Java输入输出流(14页珍藏版)》请在金锄头文库上搜索。1、山 西 大 学 计 算 机 与 信 息 技 术 学 院实 验 报 告姓 名 颜 凯 丽 学 号 2010242100 专业班级 软件工程一班课程名称 Java …

java获取子路径_Java中路径的获取

1.Java中获取路径的方法: Class_Name.class .getResource("") // Class_Name.class .getResource("/") // 获得当前类所在路径 Java中根路径就是binClass_Name.class .getResource("user.dir") // 获得当前类所…

arm9 安装java_QT5.7 AM1808 ARM9的交叉编译

目前,我们正在开发QT,用于在AM1808处理器上运行的硬件的应用程序开发 .目前,我们使用QT创建者开发了我们的应用程序,编译器版本为Qt 4.8.7 .我们计划用Qt 5.7升级它,为此,我们从中下载相应的包我们成功下载…

php pdf 文字水印图片,php如何给pdf加上文字水印和图片水印[未测试]

php给pdf加上水印环境php5.5.12fpdi-1.5.2fpdf-1.7原理利用fpdi来加载已知pdf文件,用fpdf对pdf进行操作注意事项免费的fpdi只支持处理pdf1.4及以下版本,1.5以上就需要用到FPDI PDF-Parser插件使用方法fpdi-1.5.2fpdf-1.71.文字水印 word.phprequire_once…