目录
Java 中计数排序如何工作?
java 中计数排序的示例
结论
首页 Java java教程 java中的计数排序

java中的计数排序

Aug 30, 2024 pm 03:58 PM
java

计数排序是一种在任何编程语言中都发挥着关键作用的算法,Java 也是如此。计数排序算法的主要目标是根据以小整数形式出现的键对对象集合进行排序,以用于对算法进行排序。它主要对键值对进行操作和计数,根据输出序列呈现元素的位置。  这种排序的运行时间与项目成线性关系,然后键值之间的差异位于最大值和最小值之间。

开始您的免费软件开发课程

网络开发、编程语言、软件测试及其他

语法

Java 中执行计数排序没有特定的语法,但有一个逻辑流程,以算法的形式逐步根据输入执行计数排序,表示如下:

Class name {
Method name following sorting ()
{
# Find the length of array defined;
#the output character array will have sorted array
#Create a count arr to store count of each element, characters and initialize it 0
#Store count of each character element in the array
#Build output character and write the logic to make it operated in reverse order
#that builds output can now be copied from the previous array to the current
#Make use of the driver code to move and proceed.
}
登录后复制

Java 中计数排序如何工作?

  • 如前所述,计数排序算法在编程中起着重要作用;它对以收集格式存在的对象进行排序,并用于计算具有不同键和值对的存在元素的数量,并再次与算术计数一起使用,确定每个键值对存在的每个元素的位置最小值和最大值之间的差。
  • 如果检查的话,运行时间或时间复杂度本质上是线性的,具有数组中的所有元素以及最小和最大键值之间的差异,因此这些元素和排序技术适合直接使用键变化的情况不显着大于具有所需键的元素。
  • 虽然还有另一种算法可以支持大部分的key处理,但它的效率不如按要求计数排序和散列,因此可以用基数排序代替,以处理与以前相比大量key的情况.
  • 由于计数排序使用键和值对作为数组索引值的一部分,因此它不被视为比较排序。另外,比较排序的下限也是不允许的。
  • 桶排序也只是在相同的任务和类似的时间分析下才低于计数排序,但与当时的计数排序相比,桶排序需要动态数组、链表或大量内存来容纳存储桶中存在的元素,然后计数排序仅存储每个存储桶中单独的单个数字的值。
  • 存在某些输入和输出假设序列,因为计数排序的输入由 n 个项目的集合组成,其中每个项目都有非负整数键值,最大值的值为 k。计数排序的一些描述是对整数的线性格式序列进行简单排序的输入。
  • 数组的输出大多不包含具有某种键顺序的主要项目,但需要根据要求检查其使用。
  • 计数 Sort 的时间复杂度为 O (n+l),其中 n 是元素数量,l 是考虑输入的范围。
  • 此外,辅助空间仅为 O(n+l)。

java 中计数排序的示例

该程序通过考虑一些输入和输出序列集作为 Java 排序的一部分来演示计数排序。

代码

public class Counting_Sort_1{
void sort_0(char arr_0[])
{
int n_8 = arr_0.length;
char output_val[] = new char[n_8];
int count_0[] = new int[528];
for (int l_0 = 0; l_0 < 528; ++l_0)
count_0[l_0] = 0;
for (int y_1 = 0; y_1 < n_8; ++y_1)
++count_0[arr_0[y_1]];
for (int l_0 = 1; l_0 <= 526; ++l_0)
count_0[l_0] += count_0[l_0 - 1];
for (int l_0 = n_8 - 1; l_0 >= 0; l_0--) {
output_val[count_0[arr_0[l_0]] - 1] = arr_0[l_0];
--count_0[arr_0[l_0]];
}
for (int l_0 = 0; l_0 < n_8; ++l_0)
arr_0[l_0] = output_val[l_0];
}
public static void main(String []args){
Counting_Sort_1 ob = new Counting_Sort_1();
char arr_0[] = { 's', 'a', 'r', 'c', 's', 'f', 'o',
'i', 'n', 'c', 'a', 'r', 'm' };
ob.sort_0(arr_0);
System.out.print("Sorted_character_array_in_Counting_Sort ");
for (int l = 0; l < arr_0.length; ++l)
System.out.print(arr_0[l]);
}
}
登录后复制

输出:

java中的计数排序

说明

在上面的示例中,我们在 Java 中实现了计数排序,其中遵循以下步骤才能正确执行:

  • 创建一个具有 Selection_Sort_0 的类,然后遵循该类的输入集。
  • 创建类后,就会创建一个方法来存储将具有排序数组的字符数组。
  • 创建计数数组,其意义是将值作为独立实体以键和值对的形式存储,进一步以字符形式存储为计数。
  • 需要更改计数来计算输出数组中当前字符的实际值和位置。
  • 使用字符集构建输出数组,使其稳定并可逆序操作。
  • 将排序后的数组复制到当前数组,以某种方式或另一种方式对数组进行排序。
  • 执行驱动程序代码以进一步驱动整个代码库,以从输入源获取输出。

结论

计数排序是一种排序算法,应用于由一系列元素组成的数组上进行排序。排序将基于数组中存在的键和值对或最小值或最大值的差异。当需要批量使用整数实现时,计数排序给开发者提供了很多帮助。

以上是java中的计数排序的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

突破或从Java 8流返回? 突破或从Java 8流返回? Feb 07, 2025 pm 12:09 PM

Java 8引入了Stream API,提供了一种强大且表达力丰富的处理数据集合的方式。然而,使用Stream时,一个常见问题是:如何从forEach操作中中断或返回? 传统循环允许提前中断或返回,但Stream的forEach方法并不直接支持这种方式。本文将解释原因,并探讨在Stream处理系统中实现提前终止的替代方法。 延伸阅读: Java Stream API改进 理解Stream forEach forEach方法是一个终端操作,它对Stream中的每个元素执行一个操作。它的设计意图是处

PHP:网络开发的关键语言 PHP:网络开发的关键语言 Apr 13, 2025 am 12:08 AM

PHP是一种广泛应用于服务器端的脚本语言,特别适合web开发。1.PHP可以嵌入HTML,处理HTTP请求和响应,支持多种数据库。2.PHP用于生成动态网页内容,处理表单数据,访问数据库等,具有强大的社区支持和开源资源。3.PHP是解释型语言,执行过程包括词法分析、语法分析、编译和执行。4.PHP可以与MySQL结合用于用户注册系统等高级应用。5.调试PHP时,可使用error_reporting()和var_dump()等函数。6.优化PHP代码可通过缓存机制、优化数据库查询和使用内置函数。7

PHP与Python:了解差异 PHP与Python:了解差异 Apr 11, 2025 am 12:15 AM

PHP和Python各有优势,选择应基于项目需求。1.PHP适合web开发,语法简单,执行效率高。2.Python适用于数据科学和机器学习,语法简洁,库丰富。

PHP与其他语言:比较 PHP与其他语言:比较 Apr 13, 2025 am 12:19 AM

PHP适合web开发,特别是在快速开发和处理动态内容方面表现出色,但不擅长数据科学和企业级应用。与Python相比,PHP在web开发中更具优势,但在数据科学领域不如Python;与Java相比,PHP在企业级应用中表现较差,但在web开发中更灵活;与JavaScript相比,PHP在后端开发中更简洁,但在前端开发中不如JavaScript。

PHP与Python:核心功能 PHP与Python:核心功能 Apr 13, 2025 am 12:16 AM

PHP和Python各有优势,适合不同场景。1.PHP适用于web开发,提供内置web服务器和丰富函数库。2.Python适合数据科学和机器学习,语法简洁且有强大标准库。选择时应根据项目需求决定。

Java程序查找胶囊的体积 Java程序查找胶囊的体积 Feb 07, 2025 am 11:37 AM

胶囊是一种三维几何图形,由一个圆柱体和两端各一个半球体组成。胶囊的体积可以通过将圆柱体的体积和两端半球体的体积相加来计算。本教程将讨论如何使用不同的方法在Java中计算给定胶囊的体积。 胶囊体积公式 胶囊体积的公式如下: 胶囊体积 = 圆柱体体积 两个半球体体积 其中, r: 半球体的半径。 h: 圆柱体的高度(不包括半球体)。 例子 1 输入 半径 = 5 单位 高度 = 10 单位 输出 体积 = 1570.8 立方单位 解释 使用公式计算体积: 体积 = π × r2 × h (4

PHP:许多网站的基础 PHP:许多网站的基础 Apr 13, 2025 am 12:07 AM

PHP成为许多网站首选技术栈的原因包括其易用性、强大社区支持和广泛应用。1)易于学习和使用,适合初学者。2)拥有庞大的开发者社区,资源丰富。3)广泛应用于WordPress、Drupal等平台。4)与Web服务器紧密集成,简化开发部署。

创造未来:面向零基础的 Java 编程 创造未来:面向零基础的 Java 编程 Oct 13, 2024 pm 01:32 PM

Java是热门编程语言,适合初学者和经验丰富的开发者学习。本教程从基础概念出发,逐步深入讲解高级主题。安装Java开发工具包后,可通过创建简单的“Hello,World!”程序实践编程。理解代码后,使用命令提示符编译并运行程序,控制台上将输出“Hello,World!”。学习Java开启了编程之旅,随着掌握程度加深,可创建更复杂的应用程序。

See all articles