【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);
}

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值