Leetcode 1814. Count Nice Pairs in an Array

Posted SnailTyan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Leetcode 1814. Count Nice Pairs in an Array相关的知识,希望对你有一定的参考价值。

文章作者:Tyan
博客:noahsnail.com  |  CSDN  |  简书

1. Description

Count Nice Pairs in an Array

2. Solution

**解析:**Version 1,由题目可知nums[i] - rev(nums[i])相等的两个数即可构成一个合适的对,因此统计nums[i] - rev(nums[i])相等的数值即可。

  • Version 1
class Solution:
    def countNicePairs(self, nums: List[int]) -> int:
        count = 0
        n = len(nums)
        stat = {}
        MODULE = 10**9 + 7
        for i in range(n):
            diff = nums[i] - int(str(nums[i])[::-1])
            stat[diff] = stat.get(diff, 0) + 1
            if stat[diff] > 1:
                count += stat[diff] - 1
        return count % MODULE

Reference

  1. https://leetcode.com/problems/count-nice-pairs-in-an-array/

以上是关于Leetcode 1814. Count Nice Pairs in an Array的主要内容,如果未能解决你的问题,请参考以下文章

[LeetCode] 1248. Count Number of Nice Subarrays

统计「优美子数组」

leetcode-11:1814. 统计一个数组中好对子的数目

leetcode-11:1814. 统计一个数组中好对子的数目

leetcode-11:1814. 统计一个数组中好对子的数目

ARTS- 20200713-20200719