当前位置: 首页 > news >正文

leetcode 912. 排序数组

912. 排序数组

  • 912. 排序数组

题目

给你一个整数数组 nums,请你将该数组升序排列。
你必须在 不使用任何内置函数 的情况下解决问题,时间复杂度为 O(nlog(n)),并且空间复杂度尽可能小。
示例 1:
输入:nums = [5,2,3,1]
输出:[1,2,3,5]
示例 2:
输入:nums = [5,1,1,2,0,0]
输出:[0,0,1,1,2,5]
提示:
1 <= nums.length <= 5 * 104
-5 * 104 <= nums[i] <= 5 * 104

题解

  • 接收一个数组 nums,通过计数排序的方法对数组进行排序,并返回排序后的新数组 newArr
  • 时间复杂度: O(n+k)

    找出最大值和最小值的循环遍历了数组 nums 一次,时间复杂度为O(n) ,其中 n是数组 nums 的长度。
    统计元素出现次数的循环也遍历了数组 nums 一次,时间复杂度为O(n) 。
    根据计数数组重建排序后的数组的循环遍历了计数数组 arr 一次,时间复杂度为O(k) ,其中k是计数数组的长度(k=max - min +1)。
    总的时间复杂度为O(n+k)。

/*** @param {number[]} nums* @return {number[]}*/
var sortArray = function (nums) {// 找最大最小值let max = 0;let min = 0;for (let i = 0; i < nums.length; i++) {max = max > nums[i] ? max : nums[i];min = min < nums[i] ? min : nums[i];}const newArr = [];// 初始化数组长度为参数长度const arr = new Array(max - min + 1).fill(0);// 统计每一个值出现的次数for (let i = 0; i < nums.length; i++) {let arrIndex = nums[i] - min;if (arr[arrIndex] !== undefined) {arr[arrIndex] += 1;} else {arr[arrIndex] = 1;}}// 把有值的数据放到新数组里for (let i = 0; i < arr.length; i++) {const list = new Array(arr[i]).fill(min + i);newArr.push(...list);}return newArr;
};
http://www.lryc.cn/news/543873.html

相关文章:

  • 【芯片设计】NPU芯片前端设计工程师面试记录·20250227
  • BUU40 [CSCCTF 2019 Qual]FlaskLight1【SSTI】
  • WiFi IEEE 802.11协议精读:IEEE 802.11-2007,6,MAC service definition MAC服务定义
  • 2025学年安徽省职业院校技能大赛 “信息安全管理与评估”赛项 比赛样题任务书
  • VAE变分自编码器的初步理解
  • 2025 最新版鸿蒙 HarmonyOS 开发工具安装使用指南
  • Rider 安装包 绿色版 Win/Mac/Linux 适合.NET和游戏开发者使用 2025全栈开发终极指南:从零配置到企业级实战
  • Python常见面试题的详解24
  • 手机打电话时如何识别对方按下的DTMF按键的字符-安卓AI电话机器人
  • RabbitMQ操作实战
  • IDEA 2024.1 最新永久可用(亲测有效)
  • 【R包】pathlinkR转录组数据分析和可视化利器
  • RPA 与 AI 结合:开启智能自动化新时代
  • [免费]Springboot+Vue在线文档管理系统【论文+源码+SQL脚本】
  • 内容选题与商业布局
  • 文字描边实现内黄外绿效果
  • 网络协议 HTTP、HTTPS、HTTP/1.1、HTTP/2 对比分析
  • 千峰React:Hooks(上)
  • salesforce 为什么无法关闭task,显示:insufficient access rights on object id
  • 机器学习:强化学习的epsilon贪心算法
  • MongoDB—(一主、一从、一仲裁)副本集搭建
  • MyBatis TypeHandler 详解与实战:FastJson 实现字符串转 List
  • 第二十八:5.5.【storeToRefs】5.6.【getters】
  • APISIX Dashboard上的配置操作
  • MinIO在 Docker中修改登录账号和密码
  • 英文论文查重,Turnitin和IThenticate两个系统哪个更合适?
  • pnpm的基本用法
  • 【实战中提升自己】防火墙篇之双ISP切换与VRRP切换对于用户的体验
  • Go在1.22版本修复for循环陷阱
  • Nginx+PHP+MYSQL-Ubuntu在线安装