前端算法 === 计数排序

news2024/11/15 10:53:22

目录

计数排序算法的起源

算法的基本原理

算法的实现

代码示例

算法的优势与局限性

计数排序的应用场景


计数排序是一种简单而高效的排序算法,特别适合于处理一定范围内的整数排序问题。它的核心思想是利用额外的存储空间来记录数组中每个元素出现的次数,然后根据这些计数来重新构建一个有序的数组。以下是对计数排序算法的详细介绍

计数排序算法的起源

计数排序算法最早由H.B.Hoare在1961年提出,它是一种非比较排序算法,与冒泡排序、选择排序等基于比较的排序算法相比,计数排序在特定条件下具有显著的性能优势。

算法的基本原理

计数排序的基本思想可以概括为“计数-累加-分配”三个步骤:

  1. 计数:创建一个计数数组,用于记录每个元素在原始数组中出现的次数。
  2. 累加:将计数数组中的每个元素累加,得到每个元素在排序后数组中的最终位置。
  3. 分配:根据累加后的计数数组,将原始数组中的元素按照排序后的顺序分配到新数组中。

算法的实现

在实现计数排序算法时,我们首先需要确定数组中的最大值,以便确定计数数组的大小。然后,我们遍历原始数组,统计每个元素的出现次数。接下来,我们通过累加计数数组中的元素,确定每个元素在新数组中的位置。最后,我们根据这些位置信息,将原始数组中的元素重新排列到新数组中。

代码示例

let arr = [5, 7, 5, 4, 9, 1];

function countSort(arr) {
  // 如果数组长度小于2,则直接返回数组
  if (arr.length < 2) {
    return arr;
  }

  // 找到数组中的最大值
  let max = Math.max(...arr);

  // 创建一个计数数组,长度为最大值加1
  const counts = new Array(max + 1);

  // 遍历原始数组,统计每个元素出现的次数
  arr.forEach((item) => {
    if (!counts[item]) {
      counts[item] = 0;
    }
    counts[item]++;
  });

  // 创建一个新数组来存储排序后的结果
  let newArray = [];
  let SortIndex = 0;

  // 遍历计数数组,根据元素出现的次数,依次填充到新数组中
  counts.forEach((item, index) => {
    while (item > 0) {
      //  可以先使用 SortIndex 的当前值,然后再将 SortIndex 值加1,
      newArray[SortIndex++] = index;
      item--;
    }
  });

  return newArray;
}

console.log(countSort(arr));

算法的优势与局限性

计数排序算法的优势在于其时间复杂度为O(n+k),其中n是数组的长度,k是数组中的最大值。这使得计数排序在处理小范围整数排序时非常高效。然而,计数排序的空间复杂度也是O(k),如果k非常大,算法的空间消耗也会相应增加。

计数排序的应用场景

计数排序算法在以下场景中特别有用:

  • 当数据范围(k)远小于数组长度(n)时。
  • 当需要对固定范围的整数进行排序时。
  • 在数据分布比较均匀的情况下。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2070872.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Ansible远程自动化运维

目录 概念 安装ansible modules模块和语法 命令行语法 模块 1. command 基础模块 常用的参数 2. shell模块 3. cron定时任务模块 4. user用户管理模块 参数 5. copy复制模块 参数 6. file模块 设置文件属性 参数 实验&#xff1a;批量创建目录 7…

staticHeader(静态标头)

<!DOCTYPE html> <html lang"zh-CN"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>staticHeader(静态标头)</title> </head…

C语言函数介绍(上)

函数概念库函数标准库和头文件库函数的使用方法头文件包含库函数文档的一般格式 自定义函数函数的语法形式函数例子 形参和实参实参形参实参和形参的关系 return 语句数组做函数参数 函数概念 数学中我们其实就见过函数的概念&#xff0c;比如&#xff1a;一次函数 ykxb &…

msvcp120.dll丢失是怎么回事?几种靠谱修复msvcp120.dll的方法

在使用基于Windows的计算机进行日常工作或娱乐时&#xff0c;您可能会遇到一个错误消息&#xff1a;“无法启动此程序&#xff0c;因为计算机中丢失msvcp120.dll。”这样的提示通常在尝试启动某些程序或游戏时弹出&#xff0c;导致应用无法正常运行。这个问题通常与系统中的某个…

redis是什么?看着一篇就够了

目录 介绍一下 redis 数据库&#xff1f; redis数据类型与应用场景 redis 为什么更快&#xff1f; redis 怎么实现持久化的&#xff1f; AOF 日志是如何实现的&#xff1f; RDB 快照是如何实现的呢&#xff1f; 混合持久化 redis 单线程在多核机器里使用会不会浪费…

LABVIEW数据保存文件

这里推荐选用CSV文件&#xff1f;为什么&#xff1f; 下表是格式差异造成的容量差异。 具体原因&#xff0c;总结为以下两点&#xff1a; 首先&#xff0c;CSV文件能使用EXCEL打开&#xff0c;方便查阅和借助EXCEL工具进一步处理。 第二&#xff0c;相对来说&#xff0c;CSV…

Web自动化测试:selenium使用详解

&#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 说到自动化测试&#xff0c;就不得不提大名鼎鼎的Selenium。Selenium 是如今最常用的自动化测试工具之一&#xff0c;支持快速开发自动化测试框架&#xff0c;…

深信服上半年亏损5.92亿,营收同比降低2.3亿

吉祥知识星球http://mp.weixin.qq.com/s?__bizMzkwNjY1Mzc0Nw&mid2247485367&idx1&sn837891059c360ad60db7e9ac980a3321&chksmc0e47eebf793f7fdb8fcd7eed8ce29160cf79ba303b59858ba3a6660c6dac536774afb2a6330#rd 《网安面试指南》http://mp.weixin.qq.com/s?…

Qt:玩转QPainter序列二

前言 接着序列一开始序列二。 正文 继续先看源码&#xff0c;下面是分析 1. Q_FLAG(RenderHint) Q_FLAG是Qt宏&#xff0c;用于向Qt的元对象系统&#xff08;Meta-Object System&#xff09;注册枚举值&#xff0c;以便可以在Qt的元对象系统中使用这些枚举值。例如&#…

SD 卡无法读取?这十大方法助你轻松修复!

在我们的日常生活中&#xff0c;SD 卡被广泛应用于各种设备&#xff0c;如数码相机、手机、平板电脑等。然而&#xff0c;有时我们可能会遇到 SD 卡无法读取的情况&#xff0c;这让人十分苦恼。别担心&#xff0c;下面为你介绍多种修复 SD 卡无法读取问题的方法。 一、检查硬件…

如何知道当前网卡连接的下位机的IP,通过工具实现

要确定当前网卡连接的下位机的 IP 地址&#xff0c;可以使用以下几种工具和方法来实现。 1. 使用 arp-scan 工具 arp-scan 是一个强大的网络扫描工具&#xff0c;可以用于扫描网络上的设备并显示它们的 IP 和 MAC 地址。 安装 arp-scan&#xff1a; sudo apt update sudo a…

合宙LuatOS开发板使用说明——Air700ECQ

EVB-Air700ECQ-IO 开发板是合宙通信推出的基于 Air700ECQ 模组所开发的&#xff0c;包含电 源&#xff0c; SIM 卡&#xff0c;USB &#xff0c;天 线&#xff0c; 全 IO 引 出的最 小硬 件系 统。以 方便 用户 在设 计前期 对 Air700ECQ 模块进行性能评估&#xff0c;功能调试…

AutoMapperSQL

AutoMapperSQL--Mybatis实用小工具&#xff1a;根据数据模型、数据访问接口自动生成 mysql、sql server、oracle 三种数据源类型的表脚本及mybatis接口类对应的mapper-xml文件。 1、指定数据访问接口 mapper interface 目录路径&#xff1b; 2、指定数据模型目录路径&#xff1…

机器学习-OpenCV运用(1)

文章目录 一、OpenCV介绍二、OpenCV运用1.读取保存图片2.读取视频3.图像切片 一、OpenCV介绍 OpenCV&#xff08;Open Source Computer Vision Library&#xff09;是一个开源的计算机视觉和机器学习软件库&#xff0c;它主要用于实时的图像处理和计算机视觉任务。虽然OpenCV本…

ARM架构与ARM内核

参考&#xff1a;https://blog.csdn.net/qq_34160841/article/details/105611131 到底什么是Cortex、ARMv8、arm架构、ARM指令集、soc&#xff1f;一文帮你梳理基础概念 认识ARM、Cortex-M内核&#xff0c;以及ARMv8-M架构 ARM架构 ARM的架构指的是ARM的指令集架构。ARM指令集…

基于WordPress搭建的写真网站整站打包代码,可直接运营

直接服务器整站源码数据库打包了。 这个包的资源非常多&#xff0c;也非常火爆&#xff0c;吸引力还是挺大的。用这个架设一个引流网站还是轻松的。 图片太多太敏感&#xff0c;就不在这里显示了&#xff0c;懂的都懂。 代码测试过了&#xff0c;运行是完全没问题的。已经好…

CSS学习【margin为负值】

目录 margin塌陷时合并规则 margin重叠概念 可能会发生的情况 外边距重叠计算规则 兄弟元素之间合并&#xff0c;都为负值 当“.box1”和“.box2”都未设置外间距时&#xff1a; 给“.box1”和“.box2”设置外间距后&#xff1a; 兄弟元素间合并&#xff0c;一正一负 …

深入解析SSRF和Redis未授权访问

深入解析SSRF和Redis未授权访问&#xff1a;漏洞分析与防御 在网络安全领域&#xff0c;服务器端请求伪造&#xff08;SSRF&#xff09; 和 Redis未授权访问 是两类常见且危险的安全漏洞。 1.2 SSRF攻击的利用 1.2.1 测试并确认SSRF漏洞 一个典型的例子是&#xff0c;当应用…

迭代器的失效问题

vector的插入与删除 我们首先举例说明vector插入和删除操作返回的是什么迭代器 void print(std::vector<int>& vec) {for(auto itvec.begin();it!vec.end();it)std::cout<<*it<<" ";std::cout<<std::endl; }void test() {/*初始化vect…

Simple RPC - 07 从零开始设计一个服务端(下)_RPC服务的实现

文章目录 PreRPC服务实现服务注册请求处理 设计&#xff1a; 请求分发机制 Pre Simple RPC - 01 框架原理及总体架构初探 Simple RPC - 02 通用高性能序列化和反序列化设计与实现 Simple RPC - 03 借助Netty实现异步网络通信 Simple RPC - 04 从零开始设计一个客户端&#…