当前位置: 首页 > 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/a/283133.html

相关文章:

  • 【前端学习指南】Vue computed 计算属性 watch 监听器
  • 嵌入式硬件杂谈(一)-推挽 开漏 高阻态 上拉电阻
  • springboot 之 整合springdoc2.6 (swagger 3)
  • 金价大跌,特朗普胜选或成导火索
  • 软件测试项目实战
  • 场景解决之mybatis当中resultType= map时,因某个字段为null导致返回的map的key不存在怎么处理
  • 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++项目示例!