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

【Leetcode 2341 】 数组能形成多少数对 —— 去重

给你一个下标从 0 开始的整数数组 nums 。在一步操作中,你可以执行以下步骤:

  • 从 nums 选出 两个 相等的 整数
  • 从 nums 中移除这两个整数,形成一个 数对

请你在 nums 上多次执行此操作直到无法继续执行。

返回一个下标从 0 开始、长度为 2 的整数数组 answer 作为答案,其中 answer[0] 是形成的数对数目,answer[1] 是对 nums 尽可能执行上述操作后剩下的整数数目。

示例 1:

输入:nums = [1,3,2,1,3,2,2]
输出:[3,1]
解释:
nums[0] 和 nums[3] 形成一个数对,并从 nums 中移除,nums = [3,2,3,2,2] 。
nums[0] 和 nums[2] 形成一个数对,并从 nums 中移除,nums = [2,2,2] 。
nums[0] 和 nums[1] 形成一个数对,并从 nums 中移除,nums = [2] 。
无法形成更多数对。总共形成 3 个数对,nums 中剩下 1 个数字。

示例 2:

输入:nums = [1,1]
输出:[1,0]
解释:nums[0] 和 nums[1] 形成一个数对,并从 nums 中移除,nums = [] 。
无法形成更多数对。总共形成 1 个数对,nums 中剩下 0 个数字。

示例 3:

输入:nums = [0]
输出:[0,1]
解释:无法形成数对,nums 中剩下 1 个数字。

提示:

  • 1 <= nums.length <= 100
  • 0 <= nums[i] <= 100

去重

function numberOfPairs(nums: number[]): number[] {
  const numSet = new Set<number>();
  let count = 0;
  for (const n of nums) {
    if (numSet.has(n)) {
      numSet.delete(n);
      count++;
    } else {
      numSet.add(n);
    }
  }
  return [count, numSet.size];
}


http://www.kler.cn/a/286361.html

相关文章:

  • 【外文原版书阅读】《机器学习前置知识》2.用看电影推荐的例子带你深入了解向量点积在机器学习的作用
  • 论文阅读(八):结构方程模型用于研究数量遗传学中的因果表型网络
  • 记录一次Sqoop从MySQL导入数据到Hive问题的排查经过
  • 【Block总结】OutlookAttention注意力,捕捉细节和局部特征|即插即用
  • 房屋租赁系统在数字化时代中如何重塑租赁服务与提升市场竞争力
  • 1.Template Method 模式
  • 图为科技闪耀双展,AI之星智领未来
  • element的日期时间修改时间没有秒以及默认的时间时分修改
  • 数字化转型的内容框架解析,附华为数字化转型内容框架及方法论
  • 深度学习100问32:什么是梯度消失
  • 【开源 Mac 工具推荐之 5】tldr:简洁明了的命令行手册显示工具
  • 国密起步4:GmSSL3生成证书并使用tls(SM2、SSL)
  • 【C++ Primer Plus习题】8.7
  • SpringBoot3集成Spring Authorization Server搭建服务认证中心
  • Docker(完整实验版)
  • 了解内网穿透以及简单应用
  • 面试经典算法150题系列-找出字符串中第一个匹配项的下标
  • 从Vue的Weex迁移到Rax Weex
  • 深度学习与大模型第1课环境搭建
  • Unity编辑器开发 Immediate Mode GUI (IMGUI)
  • Java源码学习之高并发编程基础——AQS源码剖析之阻塞队列(下)
  • 深度学习实战1--决策树与随机森林(最新版本不报错)
  • 苹果笔记本电脑能不能玩游戏?苹果电脑玩游戏咋样?
  • UE5 微软输入法输入中文崩溃
  • 华为 HCIP-Datacom H12-821 题库 (3)
  • 单击视角复位按钮,即可看到整个地球【mars3d】