java记录 - 基数排序

文章目录

基数排序

思想:
在这里插入图片描述
在这里插入图片描述
排序演示

import java.text.SimpleDateFormat; 
import java.util.Arrays;
import java.util.Date;

public class Ceshi {
	public static void main(String[] args) {
		int len = 10;
		int[] arr = new int[len];
			for (int i = 0; i < len; i++) {
			arr[i] = (int) (Math.random() * 100 * len); // 生成一个[0,1000) 数
		}
		
		System.out.println("基数排序前 " + Arrays.toString(arr));

		radixSort(arr);//

		System.out.println("基数排序后 " + Arrays.toString(arr));
	}

	//基数排序方法
	public static void radixSort(int[] arr) {

	//1. 得到数组中最大的数的位数
	int max = arr[0]; //假设第一数就是最大数
	for(int i = 1; i < arr.length; i++) {
		if (arr[i] > max) {
			max = arr[i];
		}
	}

	//得到最大数是几位数
	int maxLength = (max + "").length();

	//定义一个二维数组,表示 10 个桶,  每个桶就是一个一维数组
	//说明
	//1. 二维数组包含 10 个一维数组
	//2. 为了防止在放入数的时候,数据溢出,则每个一维数组(桶),大小定为 arr.length
	//3. 名明确,基数排序是使用空间换时间的经典算法
	int[][] bucket = new int[10][arr.length];
	//为了记录每个桶中,实际存放了多少个数据,我们定义一个一维数组来记录各个桶的每次放入的数据个数
	//可以这里理解
	//比如:bucketElementCounts[0] , 记录的就是	bucket[0] 桶的放入数据个数
	int[] bucketElementCounts = new int[10];


	//第 1 轮(针对每个元素的个位进行排序处理) 
	for(int j = 0; j < arr.length; j++) {
		//取出每个元素的个位的值
		int digitOfElement = arr[j] / 1 % 10;
		//放入到对应的桶中
		bucket[digitOfElement][bucketElementCounts[digitOfElement]] = arr[j]; bucketElementCounts[digitOfElement]++;
	}
	//按照这个桶的顺序(一维数组的下标依次取出数据,放入原来数组) 
	int index = 0;
	//遍历每一桶,并将桶中是数据,放入到原数组
	for(int k = 0; k < bucketElementCounts.length; k++) {
		//如果桶中,有数据,我们才放入到原数组
		if(bucketElementCounts[k] != 0) {
			//循环该桶即第 k 个桶(即第 k 个一维数组),  放入
			for(int l = 0; l < bucketElementCounts[k]; l++) {
				//取出元素放入到 arr 
				arr[index++] = bucket[k][l];
			}
		}

		//第 l 轮处理后,需要将每个 bucketElementCounts[k] = 0  !!!!

		bucketElementCounts[k] = 0;


	}
	System.out.println("第 1 轮,对个位的排序处理 arr =" + Arrays.toString(arr));

	//==========================================

	//第 2 轮(针对每个元素的十位进行排序处理) 
	for (int j = 0; j < arr.length; j++) {
		// 取出每个元素的十位的值
		int digitOfElement = arr[j] / 10 % 10; //748 / 10 => 74 % 10 => 4
		// 放入到对应的桶中
		bucket[digitOfElement][bucketElementCounts[digitOfElement]] = arr[j]; bucketElementCounts[digitOfElement]++;
	}
	// 按照这个桶的顺序(一维数组的下标依次取出数据,放入原来数组) 
	index = 0;
	// 遍历每一桶,并将桶中是数据,放入到原数组
	for (int k = 0; k < bucketElementCounts.length; k++) {
		// 如果桶中,有数据,我们才放入到原数组
		if (bucketElementCounts[k] != 0) {
			// 循环该桶即第 k 个桶(即第 k 个一维数组), 放入
			for (int l = 0; l < bucketElementCounts[k]; l++) {
				// 取出元素放入到 arr 
				arr[index++] = bucket[k][l];
			}
		}
		//第 2 轮处理后,需要将每个 bucketElementCounts[k] = 0  !!!!
		bucketElementCounts[k] = 0;
	}
	System.out.println("第 2 轮,对十位的排序处理 arr =" + Arrays.toString(arr));

	//==========================================

	//第 3 轮(针对每个元素的百位进行排序处理) 
	for (int j = 0; j < arr.length; j++) {
		// 取出每个元素的百位的值
		int digitOfElement = arr[j] / 100 % 10; // 748 / 100 => 7 % 10 = 7
		// 放入到对应的桶中
		bucket[digitOfElement][bucketElementCounts[digitOfElement]] = arr[j]; bucketElementCounts[digitOfElement]++;
	}
	// 按照这个桶的顺序(一维数组的下标依次取出数据,放入原来数组) 
	index = 0;
	// 遍历每一桶,并将桶中是数据,放入到原数组
	for (int k = 0; k < bucketElementCounts.length; k++) {
		// 如果桶中,有数据,我们才放入到原数组
		if (bucketElementCounts[k] != 0) {
			// 循环该桶即第 k 个桶(即第 k 个一维数组), 放入
			for (int l = 0; l < bucketElementCounts[k]; l++) {
				// 取出元素放入到 arr 
				arr[index++] = bucket[k][l];
			}
		}
		//第 3 轮处理后,需要将每个 bucketElementCounts[k] = 0 !!!!
		bucketElementCounts[k] = 0;
	}
	System.out.println("第 3 轮,对百位的排序处理 arr =" + Arrays.toString(arr)); 

	}
}

循环遍历

import java.text.SimpleDateFormat; 
import java.util.Arrays;
import java.util.Date;

public class RadixSort {
	public static void main(String[] args) {
		int len = 10;
		int[] arr = new int[len];
		for (int i = 0; i < len; i++) {
			arr[i] = (int) (Math.random() * 100 * len); // 生成一个[0,1000) 数
		}
		
		System.out.println("基数排序前 " + Arrays.toString(arr));

		radixSort(arr);//

		System.out.println("基数排序后 " + Arrays.toString(arr));
	}

	//基数排序方法
	public static void radixSort(int[] arr) {
		//根据前面的推导过程,我们可以得到最终的基数排序代码

		//1. 得到数组中最大的数的位数
		int max = arr[0]; //假设第一数就是最大数
		for(int i = 1; i < arr.length; i++) {
			if (arr[i] > max) {
				max = arr[i];
			}
		}

		//得到最大数是几位数
		int maxLength = (max + "").length();

		//定义一个二维数组,表示 10 个桶,  每个桶就是一个一维数组
		//说明
		//1. 二维数组包含 10 个一维数组
		//2. 为了防止在放入数的时候,数据溢出,则每个一维数组(桶),大小定为 arr.length
		//3. 名明确,基数排序是使用空间换时间的经典算法
		int[][] bucket = new int[10][arr.length];
		//为了记录每个桶中,实际存放了多少个数据,我们定义一个一维数组来记录各个桶的每次放入的数据个数
		//可以这里理解
		//比如:bucketElementCounts[0] , 记录的就是	bucket[0] 桶的放入数据个数
		int[] bucketElementCounts = new int[10];

		//这里我们使用循环将代码处理

		for(int i = 0 , n = 1; i < maxLength; i++, n *= 10) {
			//(针对每个元素的对应位进行排序处理), 第一次是个位,第二次是十位,第三次是百位.. 
			for(int j = 0; j < arr.length; j++) {
				//取出每个元素的对应位的值
				int digitOfElement = arr[j] / n % 10;
				//放入到对应的桶中
				
				bucket[digitOfElement][bucketElementCounts[digitOfElement]] = arr[j]; 
				//初始化时,bucketElementCounts[digitOfElement] = = 0
				//是第0个桶的第0个

				bucketElementCounts[digitOfElement]++;//这里就是0++ = =1
				//++后,下次就放在了第0个桶的第0个的下一个了
				//bucketElementCounts[digitOfElement] = = 1

			}
			//按照这个桶的顺序(一维数组的下标依次取出数据,放入原来数组) 
			int index = 0;
			//遍历每一桶,并将桶中是数据,放入到原数组
			for(int k = 0; k < bucketElementCounts.length; k++) {
				//如果桶中,有数据,我们才放入到原数组
				if(bucketElementCounts[k] != 0) {
					//循环该桶即第 k 个桶(即第 k 个一维数组),  放入
					for(int l = 0; l < bucketElementCounts[k]; l++) {
						//取出元素放入到 arr 
						arr[index++] = bucket[k][l];
					}
				}

				//第 i+1 轮处理后,需要将每个 bucketElementCounts[k] = 0  !!!!
				bucketElementCounts[k] = 0;


			}
			System.out.println("第"+(i+1)+"轮,对位数的排序处理 arr =" + Arrays.toString(arr));
		}

	}
}

其他排序算法

插入排序:
https://blog.csdn.net/bell_love/article/details/106319609
快速排序:
https://blog.csdn.net/bell_love/article/details/106319697
选择排序:
https://blog.csdn.net/bell_love/article/details/106319578
希尔排序:
https://blog.csdn.net/bell_love/article/details/106319660
冒泡排序:
https://blog.csdn.net/bell_love/article/details/106317675
归并排序:
https://blog.csdn.net/bell_love/article/details/106319739
堆排序:
https://blog.csdn.net/bell_love/article/details/106319827

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夜里的雨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值