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

【Leetcode 2206 】 将数组划分成相等数对 —— 哈希表与数组模拟哈希表

给你一个整数数组 nums ,它包含 2 * n 个整数。

你需要将 nums 划分成 n 个数对,满足:

  • 每个元素 只属于一个 数对。
  • 同一数对中的元素 相等 。

如果可以将 nums 划分成 n 个数对,请你返回 true ,否则返回 false 。

示例 1:

输入:nums = [3,2,3,2,2,2]
输出:true
解释:
nums 中总共有 6 个元素,所以它们应该被划分成 6 / 2 = 3 个数对。
nums 可以划分成 (2, 2) ,(3, 3) 和 (2, 2) ,满足所有要求。

示例 2:

输入:nums = [1,2,3,4]
输出:false
解释:
无法将 nums 划分成 4 / 2 = 2 个数对且满足所有要求。

提示:

  • nums.length == 2 * n
  • 1 <= n <= 500
  • 1 <= nums[i] <= 500

哈希表

//哈希表
function divideArray2(nums: number[]): boolean {
  const n = nums.length;
  if (n % 2 !== 0) return false;
  const cnt = new Map<number, number>();
  for (const num of nums) {
    cnt.set(num, (cnt.get(num) || 0) + 1);
  }
  for (const [k, v] of cnt) {
    if (v % 2 !== 0) return false;
  }
  return true;
}

数组模拟哈希表

/*
https://leetcode.cn/u/cshappyeveryday/
执行用时:58 ms, 在所有 Typescript 提交中击败了100.00%的用户
内存消耗:52.59 MB, 在所有 Typescript 提交中击败了 - %的用户
时间复杂度:O(n)
2024年8月29日 
*/
function divideArray(nums: number[]): boolean {
  const n = nums.length;
  const arr = Array(501).fill(0);
  if (n % 2 !== 0) return false;
  // 时间复杂度:O(n)
  for (const num of nums) {
    arr[num]++;
  }
  //时间复杂度:O(1)
  return arr.every((n) => n % 2 === 0);
}


http://www.kler.cn/news/283133.html

相关文章:

  • Elasticsearch 中,term 查询和 match 查询的区别
  • JavaScript常见知识点总结
  • 搜维尔科技:‌XSENS高精度惯性动作捕捉系统,人形机器人Al训练专用设备
  • 华为HCIP-datacom 真题 (2024年下半年最新题库)
  • Vue + Spring Boot + SQL Server + Python 部署到 Windows 服务器
  • 最长公共子序列
  • 卡牌抽卡机小程序搭建,探索新鲜有趣的拆卡体验
  • 介绍几种常用的排序算法
  • Mysql,sqllite表结构对比
  • xxl-job升级到springboot3.0 导致页面打不开报错)问题
  • 打手机检测算法源码样本展示打手机检测算法实际应用场景介绍
  • 在Windows上用Visual Studio编译Tesseract
  • 什么是单点登录
  • VUE3生命周期钩子
  • 微软在Edge浏览器中引入本地AI模型;苹果将于9月10日发布iPhone 16系列
  • Java 入门指南:初识 Java NIO
  • cmake,make,makefile之间的关系
  • cppbase阶段汇总
  • 零售数字化:基于会员、商品和导购的智能决策
  • 提升你的校招简历:推荐高质量C++项目示例!
  • 【openwrt-21.02】T750 openwrt-21.02 Linux-5.4.238 input子系统----gpio-keys实现分析
  • 机器学习在医学中的应用
  • 自制深度学习推理框架之卷积和池化算子的设计与实现
  • 力扣题/图论/实现 Trie (前缀树)
  • 【Redis】Redis 持久化 -- RDB AOF
  • 02.标准化编程规范
  • 依赖注入:原则、实践与Spring中的应用
  • 高级java每日一道面试题-2024年8月26日-框架篇[Web篇]-如何查询网站在线人数?
  • 【并发编程】从AQS机制到同步工具类
  • SpringBoot依赖之Spring Data Redis的功能抽离公共服务