双指针选择排序算法,附源码及对数器验证,全网唯一,Java实现

我是一个从汽车行业转行IT的项目经理,我是Edward。最近一直在听马士兵马老师的算法课,第一个排序算法的作业就让我陷入了苦思冥想,选择排序固然简单,但是在一次遍历中加入了最大值的识别和换位增大了不少难度,临界情况的判定无疑是关键。为什么写这篇文章? 原因是查了不少帖子,发现虽然有不少人是用jJava实现的,但是写的都不对,写出来的程序跑了一遍1-10成立,就以为对了,真是贻害万年!

下面是实现的代码,其中关键判定处标有注释:

public class SelectionSortImproved {
   
	
	public static void sort(int[]arr) {
   
		for (int j = 0; j < arr.length/2; j++) {
   
			//一次遍历同时找出最大值和最小值并换位
			int minPos=j,maxPos=arr.length-1-j;
			for (int i = j; i <= arr.length-j-1; i++) {
      
				minPos = arr[minPos]>arr[i] ? i:minPos;
				maxPos = arr[maxPos]<arr[i] ? i:maxPos;
			}
//			System.out.println("\n"+"minPos:"+minPos+","+"maxPos:"+
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值