排序之选择排序

在计算机科学中,排序算法是最基本的算法之一。它们用于将一组数据按照一定的顺序进行排列。今天,我们将学习并深入理解Java中的选择排序算法。

选择排序简介

选择排序是一种简单直观的排序算法。它的工作原理是:第一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,然后再从剩余的未排序元素中寻找到最小(大)元素,继续放在起始位置直到未排序元素个数为0。

选择排序的步骤:

1>首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置。

2>再从剩余未排序元素中继续寻找最小(大)元素,然后放到未排序序列的起始位置。

3>重复第二步,直到所有元素均排序完毕。

Java代码实现

以下是使用Java实现选择排序的代码:

java 复制代码
import java.util.Arrays;
//选择排序
public class SelectSort {

	public static void main(String[] args) {
		int[] arr = {5,7,4,2,0,3,1,6};
		sort(arr);
		System.out.println(Arrays.toString(arr));
	}

	public static void sort(int[] arr) {
		for(int j=0;j<arr.length;j++) {
			int min = arr[j];
			int minIndex = j;
			//找到最小值
			for(int i=j+1;i<arr.length;i++) {
				if(min>arr[i]) {
					min = arr[i];
					minIndex = i;
				}
			}
			//最小值和待排序数组的第一个进行交换
			arr[minIndex] = arr[j];
			arr[j] = min;
		}
		
	}
}

在这个程序中,我们首先定义了一个整数数组arr,然后调用sort方法对其进行排序。排序完成后,我们使用System.out.printlnArrays.toString方法打印出排序后的数组。

sort方法是选择排序的核心部分。它通过两层循环来实现排序。外层循环控制每次需要比较的元素范围,内层循环则负责找出当前范围内最小的元素。当内层循环结束后,我们就找到了当前范围内的最小元素,并将其与当前元素交换。这样,我们就可以确保当前元素总是小于或等于其后面的元素。当我们完成所有的迭代后,数组就已经按照升序排列了。

相关推荐
叫我:松哥13 分钟前
基于神经网络算法的多模态内容分析系统,采用Flask + Bootstrap + ECharts + LSTM-CNN + 注意力机制
前端·神经网络·算法·机器学习·flask·bootstrap·echarts
每天学一点儿19 分钟前
【医学图像处理】SimpleITK 图像配准全流程解析
算法
不穿格子的程序员19 分钟前
从零开始写算法——回溯篇1:全排列 + 子集
算法·leetcode·深度优先·回溯
wen__xvn19 分钟前
代码随想录算法训练营DAY18第六章 二叉树part06
数据结构
Yupureki20 分钟前
《算法竞赛从入门到国奖》算法基础:入门篇-贪心算法(下)
c语言·c++·学习·算法·贪心算法
zzz海羊30 分钟前
【CS336】Transformer|2-BPE算法 -> Tokenizer封装
深度学习·算法·语言模型·transformer
_OP_CHEN31 分钟前
【算法基础篇】(四十七)乘法逆元终极宝典:从模除困境到三种解法全解析
c++·算法·蓝桥杯·数论·算法竞赛·乘法逆元·acm/icpc
杭州杭州杭州31 分钟前
pta考试
数据结构·c++·算法
YuTaoShao33 分钟前
【LeetCode 每日一题】2975. 移除栅栏得到的正方形田地的最大面积
算法·leetcode·职场和发展
少许极端41 分钟前
算法奇妙屋(二十五)-递归问题
算法·递归·汉诺塔