java算法-选择排序
选择排序算法特点:
>每一轮找出一个最小值或者最大值,依次放在最前面的位置。在查找的过程中,用当前假定的最小值或者最大值,去跟后面所有的值进行比较。如果小或者大,就把下标给那个假定的值。一轮循环完了之后,再次判断,那个当初假定的最小或者最大,是否在一轮比较之后,发生过变化,如果变化了,那假定的值就不是那一轮比较的最小或者最大,就要进行交换。相比冒泡排序,他在空间上有优势,不需要频繁的交换。
package com.ghostwu; import java.util.Random; class MySelectSort { private int[] arr; public MySelectSort(){ arr = new int[10]; Random rand = new Random(); for( int i = 0; i < arr.length; i++ ){ arr[i] = rand.nextInt( 101 ); } } public void sort(){ int min; for( int i = 0; i < arr.length; i++ ){ min = i; for( int j = i + 1; j < arr.length; j++ ){ if( arr[min] > arr[j] ) { min = j; } } if( min != i ) { int tmp = arr[min]; arr[min] = arr[i]; arr[i] = tmp; } display( "第" + ( i + 1 ) + "轮的比较结果: " ); } } public void display( String info ){ System.out.println( info ); for( int i = 0; i < arr.length; i++ ){ System.out.print( arr[i] + "\t" ); } System.out.println(); } } public class SelectSort{ public static void main( String[] args ){ MySelectSort ss = new MySelectSort(); ss.display( "排序之前:" ); ss.sort(); ss.display( "排序之后:" ); } }
执行结果:
ghostwu@dev:~/java/data_struct/sort$ java com.ghostwu.SelectSort 排序之前: 83 18 39 98 17 68 77 68 65 2 第1轮的比较结果: 2 18 39 98 17 68 77 68 65 83 第2轮的比较结果: 2 17 39 98 18 68 77 68 65 83 第3轮的比较结果: 2 17 18 98 39 68 77 68 65 83 第4轮的比较结果: 2 17 18 39 98 68 77 68 65 83 第5轮的比较结果: 2 17 18 39 65 68 77 68 98 83 第6轮的比较结果: 2 17 18 39 65 68 77 68 98 83 第7轮的比较结果: 2 17 18 39 65 68 68 77 98 83 第8轮的比较结果: 2 17 18 39 65 68 68 77 98 83 第9轮的比较结果: 2 17 18 39 65 68 68 77 83 98 第10轮的比较结果: 2 17 18 39 65 68 68 77 83 98 排序之后: 2 17 18 39 65 68 68 77 83 98
作者:ghostwu, 出处:http://www.cnblogs.com/ghostwu
博客大多数文章均属原创,欢迎转载,且在文章页面明显位置给出原文连接
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架