(兔C残篇)数组的基数排序学习笔记

2024-04-04 01:32

本文主要是介绍(兔C残篇)数组的基数排序学习笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基数排序不同于之前学习过的各类排序,基数排序是通过不断的分配和收集来实现排序的,不需要关键字比较大小的概念。

//code实现过程

import java.util.Arrays;
public class ResultArray{public static void main(String[] args){//基数排序:通过分配在收集的方式进行排序int arr[] = {10,40,5,6,30,200,178,80,90,26};//确定排序轮次,通过数组元素的最大位数来确定//获取数组中元素的最大值//int maxNumber = getMaxNumber(arr);//基数排序sortArray(arr);//输出经过基数排序之后的数组元素内容System.out.println(Arrays.toString(arr));}//定义基数排序的方法public static void sortArray(int arr[]){//根据数组中元素的最大数来确定排序轮次int max = getMaxNumber(arr);int len = String.valueOf(max).length();//定义二维数组:用于管理分配和收集动作时 存放元素的桶int arrTwo[][] = new int[10][arr.length];//定义一维数组:用于统计记录桶中收集的元素int counts[] =new int[10];for(int i=0,n=1; i<= len; i++,n*=10){//嵌套一层循环//用于控制方法接收到的数组元素,并获取位数上的整数for(int j=0; j<arr.length; j++){int ys = arr[j]/n%10;arrTwo[ys][counts[ys]++] =arr[j];}//取出桶中的元素int index =0;for(int k=0; k < counts.length; k++){if(counts[k]!=0){for(int h =0; h<counts[k]; h++){arr[index] = arrTwo[k][h]; index++;}//清除上一次统计的个数counts[k] =0;}}}}//获取数组中元素最大值的方法public static int getMaxNumber(int arr[]){//定义存储最大值的元素int max = arr[0];//遍历方法接收到的数组参数,取出数组中的最大元素for(int i =0; i < arr.length; i++){if(arr[i] > max){max =arr[i];}}return max;}}

这篇关于(兔C残篇)数组的基数排序学习笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/874485

相关文章

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

Java中数组与栈和堆之间的关系说明

《Java中数组与栈和堆之间的关系说明》文章讲解了Java数组的初始化方式、内存存储机制、引用传递特性及遍历、排序、拷贝技巧,强调引用数据类型方法调用时形参可能修改实参,但需注意引用指向单一对象的特性... 目录Java中数组与栈和堆的关系遍历数组接下来是一些编程小技巧总结Java中数组与栈和堆的关系关于

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio