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

1128. 等价多米诺骨牌对的数量

文章目录

      • 1. 题目链接
      • 2. 题目描述
      • 3. 题目示例
      • 4. 解题思路
      • 5. 题解代码
      • 6. 复杂度分析

1. 题目链接


1128. 等价多米诺骨牌对的数量 - 力扣(LeetCode)

2. 题目描述


给你一组多米诺骨牌 dominoes

形式上,dominoes[i] = [a, b]dominoes[j] = [c, d] 等价 当且仅当 (a == cb == d) 或者 (a == db == c) 。即一张骨牌可以通过旋转 0 度或 180 度得到另一张多米诺骨牌。

0 <= i < j < dominoes.length 的前提下,找出满足 dominoes[i]dominoes[j] 等价的骨牌对 (i, j) 的数量。

3. 题目示例


示例 1 :

输入:dominoes = [[1,2],[2,1],[3,4],[5,6]]
输出:1

示例 2 :

输入:dominoes = [[1,2],[1,2],[1,1],[1,2],[2,2]]
输出:3

4. 解题思路


  1. 问题理解
    • 给定一组多米诺骨牌,每个骨牌由两个数字表示,如 [a, b]
    • 两个骨牌 [a, b][c, d] 是等价的,如果 a == c && b == da == d && b == c
    • 需要统计所有等价骨牌对的数量。
  2. 关键思路
    • 将每个骨牌标准化为 [min(a, b), max(a, b)],这样可以统一等价骨牌的表示形式。
    • 使用一个二维数组 cnt 来统计每种标准化骨牌的出现次数。
    • 对于每个骨牌,其等价对的数量就是之前已经出现的相同标准化骨牌的数量。
  3. 优化点
    • 标准化处理避免了重复比较,直接通过计数数组快速查询和更新。
    • 时间复杂度为 O(n),空间复杂度为 O(1)(因为 cnt 的大小固定为 10x10)。

5. 题解代码


class Solution {public int numEquivDominoPairs(int[][] dominoes) {int ans = 0; // 初始化等价骨牌对的数量int[][] cnt = new int[10][10]; // 创建一个10x10的计数数组,用于统计每种骨牌的出现次数for (int[] d : dominoes) { // 遍历每个骨牌int a = Math.min(d[0], d[1]); // 获取骨牌中的较小值int b = Math.max(d[0], d[1]); // 获取骨牌中的较大值,保证a <= bans += cnt[a][b]++; // 将当前骨牌的计数加到ans中,并更新计数}return ans; // 返回等价骨牌对的总数}
}

6. 复杂度分析


  1. 时间复杂度
    • 遍历所有骨牌需要 O(n) 时间,其中 n 是骨牌的数量。
    • 每个骨牌的处理(标准化和计数更新)是 O(1) 操作。
    • 总时间复杂度为 O(n)
  2. 空间复杂度
    • 使用了一个固定大小的二维数组 cnt,大小为 10x10,因此空间复杂度为 O(1)
http://www.xdnf.cn/news/4824.html

相关文章:

  • Python Cookbook-7.7 通过 shelve 修改对象
  • HPLC+HRF双模载波组网过程简析
  • 【嵌入式开发-SDIO】
  • 前端获取流式数据并输出
  • 【Day 22】HarmonyOS车联网开发实战
  • vfrom表单设计器使用事件机制控制字段显示隐藏
  • 算法解密:除自身以外数组的乘积问题详解
  • robot_lab中amp_utils——retarget_kp_motions.py解析
  • 算法训练营第十一天|150. 逆波兰表达式求值、239. 滑动窗口最大值、347.前 K 个高频元素
  • 旅游设备生产企业的痛点 质检系统在旅游设备生产企业的应用
  • Python pandas 向excel追加数据,不覆盖之前的数据
  • <C#>log4net 的配置文件配置项详细介绍
  • python24-匿名函数
  • 2.5 特征值与特征向量
  • 二叉树的基本操作
  • es6/7练习题1
  • 微软推动智能体协同运作:支持 A2A、MCP 协议
  • mqtt选型,使用
  • 关键字where
  • Docker学习笔记
  • deeplabv3+街景图片语义分割,无需训练模型,看不懂也没有影响,直接使用,cityscapes数据集_25
  • python小说网站管理系统-小说阅读系统
  • 什么是HTML、CSS 和 JavaScript?
  • 电容的基本介绍
  • WPF 子界面修改后通知到主页面
  • 嵌入式 C 语言控制语句
  • 44 Python MySQL(PyMySQL 驱动)
  • Java的对象头:原理与源码详解
  • python实现的音乐播放器
  • 企业生产安全管理平台的功能架构