算法基础之----二元选择排序

本文介绍了二元选择排序的基本原理和操作过程。通过在序列中寻找最小和最大元素并进行交换,逐步完成排序。举例说明了排序过程,并提供了C语言的代码实现,帮助读者理解该算法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

假设有一个序列,元素个数为n,要对该序列进行排序。(升序为例)

在要排序的这一组数中,找到一个最小元素,与第1个位置(下标为0)的元素进行交换;与此同时,找到一个最大的元素,与最后一个位置的元素

(下标为n-1)进行交换。然后,再进行如上操作,从除第一个元素和最后一个元素之外的所有元素中,分别找到最大和最小的元素,分别与第二个位置(下标为1)、倒数第二个位置(下标为n-2)处的元素进行交换;

以此类推,直到第n-1个元素和第n个元素比较为止。

例如:

元素序列:  5 8 1 2 6 0 4 3 9 7

   下标:      0 1 2 3 4 5 6 7 8 9

 

第一次         0 8 1 2 6 5 4 3 1 9

第二次         0 1 7 2 6 5 4 3 8 9

….                     ….

第n/2次     0 1 2 3 4 5 6 7 8 9


手工过程:(假设一个数组array的长度为n)

第0趟:找出array中下标为0~n-1中最小的元素minValue,与array[0]交换;找到最大的元素maxValue,与array[n-1]交换。

第1趟:找出array中下标为1~n-2中最小的元素minValue,与array[1]交换;找到最大的元素maxValue,与array[n-2]交换

….

第i趟:找出array中下标为i~n-1-i中最小(或最大)的元素minValue,与array[i]交换;找到最大的元素maxValue,与array[n-1-i]交换

…..

第(n/2)-1趟:将array中下表为n/2和下标为n/2-1的元素比较,找到合适的位置,进行交换。

如此过程就完成了排序。

代码实现:(此处数组的生成采用一个随机函数生成一个无序数组)

C语言:

#include<stdio.h>
#include<malloc.h>
#include<time.h>
#include<stdlib.h>

void initData(int *data, int size, int minValue, int maxValue);
void showData(int *data, int size);
void selectSort(int *data, int size);

void selectSort(int *data, int size) {
	int i;
	int j;
	int minIndex = 0;		//标记处最小的元素的下标
	int maxIndex = size-1;		
	int minValue;		//用来交换的中间变量
	int maxValue;

	for(i = 0; i < size/2; i++) {
		int minIndex = i;
		int maxIndex = size-i-1;
	
		for(j = i; j < size-i-1; j++) {
			if(data[minIndex] > data[j]) {
				minIndex = j;
			}

			if(data[maxIndex] < data[j]) {
				maxIndex = j;
			}
		}

		minValue = data[minIndex];
		maxValue = data[maxIndex];

		data[minIndex] = data[i];
		data[maxIndex] = data[size-i-1];

		data[i] = minValue;
		data[size-i-1] = maxValue;

	}
}

void showData(int *data, int size) {
	int i;
	for(i = 0; i < size; i++) {
		printf(i == 0 ? "%d" : ", %d", data[i]);
	}
	printf("\n");
}

void initData(int *data, int size, int minValue, int maxValue) {
	int i;
	int value = maxValue-minValue+1;

	srand(time(0));
	for(i = 0; i < size; i++) {
		data[i] = minValue+rand()%value;
	}
}


int main(void) {
	int *arr;

	arr = (int *)calloc(sizeof(int), 20/*maxSize*/);

	initData(arr, 20/*maxSize*/, 1/*minValue*/, 100/*maxValue*/);
	showData(arr, 20);
	selectSort(arr, 20);
	showData(arr, 20);

	return 0;
}
Java代码实现:

import java.util.Arrays;

public class 二元SelectSort {
	public static void main(String[] args) {
		int[] array = new int[20];
		
		initData(array, 100/*maxValue*/);
		showData(array);
		
		selectSort(array);
		showData(array);
	}
	
	private static void selectSort(int[] array) {
		int len = array.length;
		if(len == 0) {
			throw new RuntimeException("array length is 0");
		}
		
		for(int i = 0; i < len/2; i++) {
			int minIndex = i;
			int maxIndex = len-1-i;
			
			for(int j = i; j < len-1-i; j++) {
				if(array[minIndex] > array[j]) {
					minIndex = j;
				}
				
				if(array[maxIndex] < array[j]) {
					maxIndex = j;
				}
			}
			
			int minValue = array[minIndex];
			int maxValue = array[maxIndex];
			
			array[minIndex] = array[i];
			array[maxIndex] = array[len-1-i];
			
			array[i] = minValue;
			array[len-1-i] = maxValue;
		}
	}

	/**
	 *显示数组
	 * @param array
	 */
	private static void showData(int[] array) {
		System.out.println(Arrays.toString(array));
	}

	/**
	 * 初始化一个数组,元素随机产生
	 * @param array		要初始化的数组
	 * @param maxValue	数组元素的最大值
	 */
	private static void initData(int[] array, int maxValue) {
		for(int i = 0; i < array.length; i++) {
			array[i] = (int)(Math.random()*maxValue);
		}
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值