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

给你一组多米诺骨牌 dominoes 。

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

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

示例 1:

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

输出:1

示例 2:

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

输出:3

提示:

1 <= dominoes.length <= 4 * 104^44

dominoes[i].length == 2

1 <= dominoes[i][j] <= 9

遍历数组,看当前遍历到的元素之前是否出现过等价的值,用哈希表保存之前出现过的值:

cpp 复制代码
class Solution {
public:
    int numEquivDominoPairs(vector<vector<int>>& dominoes) {
        int ans = 0;
        unordered_map<int, unordered_map<int, int>> cnt;
        for (vector<int> &domino : dominoes) {
            int minNum = min(domino[0], domino[1]);
            int maxNum = max(domino[0], domino[1]);

            ans += cnt[minNum][maxNum]++;
        }

        return ans;
    }
};

如果dominoes的长度为n,多米诺骨牌对的种类为m,则此算法时间复杂度为O(n),空间复杂度为O(m)。

相关推荐
2501_9418053111 分钟前
智慧零售平台中的多语言语法引擎与实时推荐系统实践
leetcode
mit6.8246 小时前
bfs|栈
算法
CoderYanger7 小时前
优选算法-栈:67.基本计算器Ⅱ
java·开发语言·算法·leetcode·职场和发展·1024程序员节
jllllyuz7 小时前
Matlab实现基于Matrix Pencil算法实现声源信号角度和时间估计
开发语言·算法·matlab
夏鹏今天学习了吗7 小时前
【LeetCode热题100(72/100)】前 K 个高频元素
leetcode
稚辉君.MCA_P8_Java7 小时前
DeepSeek 插入排序
linux·后端·算法·架构·排序算法
多多*7 小时前
Java复习 操作系统原理 计算机网络相关 2025年11月23日
java·开发语言·网络·算法·spring·microsoft·maven
덕화8 小时前
【面试宝典】线上问题逆向分析1
面试·职场和发展
美团程序员8 小时前
一篇文章教你搞定:”xx 功能如何测试?“常见面试题型!
测试工具·面试·职场和发展·测试用例
.YM.Z8 小时前
【数据结构】:排序(一)
数据结构·算法·排序算法