数据结构 排序 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,一经查实,立即删除!

相关文章

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…

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

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

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…

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都是相互独立的,他们之间并不能沟通,所以要新建一个类,将这些新建的线程管理起来,然后实现他们之间的相互通信.(类似于微信加群聊天的功能)由于一个聊天服…

lavarel php区别,laravel中{{}}和{!! !!}的区别详解

本篇文章介绍了laravel中{{}}和{!! !!}的区别,感兴趣的朋友可以参考下。laravel中{{}}和{!! !!}的区别详解1.{{}}和{!! !!} 中{{}}支持转义 一段html代码只是被当成普通的字符串输出 ,{!! !!} 不支持转义 一段html代码可以被正常的解析1.2具体什么意思呢…

php获取ios,IOS 通过描述获取UDID PHP代码版

难点在于PHP对XML的解析文件结构:第一步:新建HTML文件 用于跳转安装描述文件 必须在safari里面打开地址第二步:新建udid.mobileconfig文件PayloadContentURLhttps://www.xxx.com/pay_super/receive.phpDeviceAttributesUDIDIMEIICCIDVERSIONP…

matlab如何读取csv,Matlab:如何读取CSV文件以及如何读取带有字符串数据项的CSV文件 | 学步园...

CSV,逗号分开的文件,如果能快速的读取这些文件中的数据,无疑会帮助我们解决很多问题。1、 只有数据的CSV文件,CSV file that includes only numbers.As an example, create a text file, named as data.csv if you prefer, which …

url中隐藏php后缀,url中如何隐藏.php

url中隐藏“.php”的方法:首先找到并打开“nginx.conf”配置文件;然后添加内容“location / {ttry_files $uri $uri/ $uri.php$is_args$args;}”;最后保存修改即可。推荐:《PHP视频教程》现在很多人都喜欢用nginx作为Web服务器部署…

discuz手机客户端java,Discuz!7.2让高级搜索更全面

Discuz! 7.2 调整了对帖子的高级搜索,使高级搜索的搜索选项更细化,覆盖面更广。一、高级搜索功能介绍高级搜索界面如下图所示:1、按作者:此处可以填写发帖作者全名,也可以使用通配符"*",如填写&q…

php面向对象异常处理,PHP 错误和异常处理(下)

PHP 错误和异常处理(下)由 学院君 创建于9个月前, 最后更新于 7个月前版本号 #11723 views2 likes0 collects上篇我们讲了 PHP 中的错误报告和捕获,今天,我们来看看 PHP 程序中的异常处理。错误 vs. 异常错误与异常可以看作一对孪生兄弟,从严…

电脑运行java游戏,电脑运行软件卡顿?这几招游戏或是办公,让你速度飞起!...

许多朋友想知道他们已经购买了高端计算机,但是无论玩游戏还是运行软件,他们仍然陷于困境。今天,让我们教大家一个简单的方法来提高计算机性能。焦点:此方法大大提高了用户对高度配置的计算机的影响。如果计算机的设置不太高&#…

c matlab 数据类型,matlab中数据类型与c语言数据类型的区别?

matlab中数据类型与c语言数据类型的区别?mip版 关注:233 答案:3 悬赏:0解决时间 2021-02-23 08:46已解决2021-02-22 22:32matlab中数据类型与c语言数据类型的区别?最佳答案2021-02-22 22:42简单谈一下。1.好多类型是对应的。输入一个数,ma…

oracle数据库安装提示M,Python第13课:oracle数据库的安装

Python第13课:oracle数据库的安装时间 2019-01-22下午4:30主讲 罗恒丰地点 四楼电教室版本:11.2大小:2.06G安装文件在专班ftp里python安装文件的文件夹。一.找到 stage/cvu/cvu_prereq.xml ,编辑系统名,以适…

linux 文件怎么不让删,请问如何设置权限,可以禁止用户删除文件

原帖由 WHITLACK 于 2009-9-28 08:48 发表 针对某个文件,如何设置权限,可以禁止删除?文件权限的r-w-x好像不能禁止删除的啊,谢谢指教!1:使用粘滞位可以做到,下面是介绍.强制位与冒险位、粘滞位针对u,g&…

linux运行中望cad,国产CAD软件中望的Linux版适配UOS, 我在国产系统里试了试

可能大家都知道,以往我们在国产操作里运行的软件,很多都是国外开源的软件。在以前很长一段时间里,国产操作中,国内企业很少去适配的。据说,国产深度之所以有很多国产软件,其中一个原因就是他们一家一家去拜…

linux内核死锁检测机制 | oenhan,Linux内核CPU负载均衡机制 | OenHan

还是神奇的进程调度问题引发的,参看Linux进程组调度机制分析,组调度机制是看清楚了,发现在重启过程中,很多内核调用栈阻塞在了double_rq_lock函数上,而double_rq_lock则是load_balance触发的,怀疑当时的核间…

linux下IPROTO_TCP,TCP/IP协议栈在Linux内核中的运行时序分析

可选题目三:TCP/IP协议栈在Linux内核中的运行时序分析在深入理解Linux内核任务调度(中断处理、softirg、tasklet、wq、内核线程等)机制的基础上,分析梳理send和recv过程中TCP/IP协议栈相关的运行任务实体及相互协作的时序分析。编译、部署、运行、测评、…

vs2019Linux守护,Visual Studio 2019将支援Ninja显着提升Linux专案建置效率

微软更新Visual Studio 2019,新增多个可提升Linux开发体验的功能,包括在Linux上支援建置系统Ninja,以及更完整地支援gdbserver,而且现在开发者也可以使用连接管理器(Connection Manager),编辑和配置预设的远端连接。使…