算法排序(二)——选择排序法

本文详细介绍了选择排序法的实现过程,通过自定义的selectionSort方法,对数组进行从小到大的排序。算法思路是遍历数组,找到最小元素并交换至已排序部分的末尾,重复该过程直至完成排序。文中还提供了测试代码,展示如何对20个0~100的随机数进行排序。
摘要由CSDN通过智能技术生成

目标:实现选择排序,将数组元素从小到大进行排序

自定义方法selectionSort,传入参数为待排序数组array,返回排序完成后的数组。

思路:使用i从0到array.length-1对数组进行遍历,遍历过程中,使用minIndex变量记录最小值下标,minIndex初始值为i;接着使用变量j对数组下标为i+1~array.length-1的元素进行遍历,遍历过程中对array[j]和array[minIndex]进行比较,如果array[j]小于array[minIndex],将minIndex赋值成j,这层遍历结束后,对array[minIndex]和array[i]进行交换,这样数组中最小的数就交换到了最前面。

简单的来说,选择排序法就是每次遍历都依次把遍历范围中的最小的元素提到最前面来。

代码实现:

	//选择排序
	public static void selectionSort(int[] array){
		for(int i=0;i<array.length;i++){
			int minIndex = i;
			for(int j=i+1;j<array.length;j++){
				if(array[j]<array[minIndex]){
					minIndex = j;
				}
			}
			//交换两个数
			int temp = array[i];
			array[i] = array[minIndex];
			array[minIndex] = temp;
		}
	}

测试代码:

import java.util.Scanner;

public class Client {

	public static void main(String[] args) {
		Scanner input = new Scanner(System.in);
		int n = input.nextInt();
		int left = input.nextInt();
		int right = input.nextInt();
		int[] array = SortUtil.getRandomArrayData(n, left, right);
		System.out.println("排序前:");
		print(array);
		SortUtil.selectionSort(array);
		System.out.println("排序后:");
		print(array);
	}
	
	public static void print(int[] array){
		for(int i=0;i<array.length;i++){
			System.out.print(array[i]+" ");
		}
		System.out.println();
	}
	
}

将20个0~100的数进行排序,打印结果。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值