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

LeetCode刷题---数组---1128

等价多米诺骨牌对的数量

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

题目:

给你一组多米诺骨牌 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
  • dominoes[i].length == 2
  • 1 <= dominoes[i][j] <= 9
自己的思路和代码:
思路:

        开始时,我的思路是两次遍历,和冒泡排序的实现方式差不多,但是我写出一版来显示超出时间限制。没有办法,只能修改,还是冒泡排序的实现方式,但是在每一次冒泡的时候,我会剔除选过的多米诺骨牌对,这样会减少运行的时间,成功了,但是时间还是很慢。

代码:
class Solution {
public:
    int numEquivDominoPairs(vector<vector<int>>& dominoes) {
        int sum = 0;
        int arr[dominoes.size()];
        memset(arr, 0, sizeof(arr));
        for(int i=0; i<dominoes.size()-1; i++) {
            if(arr[i] == 1) continue;
            int temp = 0;
            for(int j=i+1; j<dominoes.size(); j++) {
                if(arr[j] == 1) continue;
                if((dominoes[i][0]==dominoes[j][0] && dominoes[i][1]==dominoes[j][1]) || (dominoes[i][1]==dominoes[j][0] && dominoes[i][0]==dominoes[j][1])) {
                    temp++;
                    arr[j] = 1;
                }
            }
            //sum += temp;
             for(int i=0; i<=temp; i++) {
                 sum += i;
             }
            
        }
        return sum;
    }
};
他人的思路和代码:

因为我自己实现的方法比较暴力,并且运行的时间也不是很理想,所以查看了题解,找了一个比较好的方法。

思路:

本题中我们需要统计所有等价的多米诺骨牌,其中多米诺骨牌使用二元对代表,「等价」的定义是,在允许翻转两个二元对的的情况下,使它们的元素一一对应相等。

于是我们不妨直接让每一个二元对都变为指定的格式,即第一维必须不大于第二维。这样两个二元对「等价」当且仅当两个二元对完全相同。

注意到二元对中的元素均不大于 9,因此我们可以将每一个二元对拼接成一个两位的正整数,即 (x,y)→10x+y。这样就无需使用哈希表统计元素数量,而直接使用长度为 100 的数组即可。

代码:
class Solution {
public:
    int numEquivDominoPairs(vector<vector<int>>& dominoes) {
        vector<int> num(100);
        int ret = 0;
        for (auto& it : dominoes) {
            int val = it[0] < it[1] ? it[0] * 10 + it[1] : it[1] * 10 + it[0];
            ret += num[val];
            num[val]++;
        }
        return ret;
    }
};

相关文章:

  • FPGA实现UltraScale GTH光口视频转USB3.0传输,基于FT601+Aurora 8b/10b编解码架构,提供2套工程源码和技术支持
  • 网页版贪吃蛇小游戏开发HTML实现附源码!
  • mysql8.0使用MGR实现高可用与利用MySQL Router构建读写分离MGR集群
  • 网络安全常识
  • 如何在微信小程序中添加动画效果
  • PyTorch Lightning Trainer介绍
  • 股指期货入门指南:股指期货的交割流程与机制
  • 以用户为中心,汽车 HMI 界面设计的创新之道
  • Polkadot-API (PAPI) 简介与使用指南
  • 为什么Pytorch中实例化模型会直接调用forward方法?
  • 【1min 快速上手 Unity 基本使用方法】外部模型使用
  • 双ESP8266-01S通讯UDP配置
  • Kubernetes(k8s)探针(Probes)
  • 游戏引擎学习第87天
  • 不到1M的工具,使用起来非常丝滑!
  • 【RK3588嵌入式图形编程】-SDL2-鼠标输入处理
  • 概率论、组合数学知识点汇总
  • AI 数字人革新术:内核揭秘、应用实战、最新进展与未来蓝图
  • 性能测试工具篇
  • 【面试】面试常见的智力题
  • 开发手机网站/百度问一问客服人工在线咨询
  • 包装设计征集网站/软文关键词排名推广
  • 政府网站建设与网络安全培训/重庆seo优化
  • 电脑搭建网站需要空间/微信公众号的推广
  • 如何做公司的网站/百度下载免费安装到桌面
  • 成都新都网站开发/网上商城推广13种方法