1128. 等价多米诺骨牌对的数量(傻瓜教程)(python)(LC)

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

给你一个由一些多米诺骨牌组成的列表 dominoes。

如果其中某一张多米诺骨牌可以通过旋转 0 度或 180 度得到另一张多米诺骨牌,我们就认为这两张牌是等价的。

形式上,dominoes[i] = [a, b]dominoes[j] = [c, d] 等价的前提是 a==c 且 b==d,或是 a==d 且 b==c

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


示例:

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

提示: 1 <= dominoes.length <= 40000; 1 <= dominoes[i][j] <= 9

思路:(自定义映射关系)

把不同的二元且具有顺序属性的值映射为同一的单元的值

1.数据结构

采用列表,对于一元的惟一的值的映射用列表就好了

		num = [0] * 100

2.映射处理

二元对中的元素均不大于9,因此我们可以将每一个二元对拼接成一个两位的正整数

		for x, y in dominoes:
            val = (x * 10 + y if x <= y else y * 10 + x)

3.计数

每一个新的多米诺骨牌将与之前所有等价的骨牌构成骨牌对
因此要累加计数

            ret += num[val]
            num[val] += 1

完整代码

class Solution:
    def numEquivDominoPairs(self, dominoes: List[List[int]]) -> int:
        num = [0] * 100
        ret = 0
        for x, y in dominoes:
            val = (x * 10 + y if x <= y else y * 10 + x)
            ret += num[val]
            num[val] += 1
        return ret

在这里插入图片描述

LC112

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Grayson Zhang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值