Skip to content
LC-3128 Medium LeetCode

3128. Right Triangles

Read the full problem statement on LeetCode.
Difficulty: medium Acceptance: 47% Topics: Array, Hash Table, Math, Combinatorics, Counting
View full problem on LeetCode
Reference solution (spoiler · python)
# Time:  O(n * m)
# Space: O(min(n, m))

# combinatorics
class Solution(object):
    def numberOfRightTriangles(self, grid):
        """
        :type grid: List[List[int]]
        :rtype: int
        """
        def get(i, j):
            return grid[i][j] if n < m else grid[j][i]

        n, m = len(grid), len(grid[0])
        result = 0
        cnt1 = [sum(get(i, j) for j in xrange(max(n, m))) for i in xrange(min(n, m))]
        for j in xrange(max(n, m)):
            cnt2 = sum(get(i, j) for i in xrange(min(n, m)))
            result += sum((cnt1[i]-1)*(cnt2-1) for i in xrange(min(n, m)) if get(i, j))
        return result


# Time:  O(n * m)
# Space: O(n + m)
# combinatorics
class Solution2(object):
    def numberOfRightTriangles(self, grid):
        """
        :type grid: List[List[int]]
        :rtype: int
        """
        n, m = len(grid), len(grid[0])
        cnt1 = [sum(grid[i][j] for j in xrange(m)) for i in xrange(n)]
        cnt2 = [sum(grid[i][j] for i in xrange(n)) for j in xrange(m)]
        return sum((cnt1[i]-1)*(cnt2[j]-1) for i in xrange(n) for j in xrange(m) if grid[i][j])


# Time:  O(n * m)
# Space: O(min(n, m))
# freq table
class Solution3(object):
    def numberOfRightTriangles(self, grid):
        """
        :type grid: List[List[int]]
        :rtype: int
        """
        def get(i, j):
            return grid[i][j] if n < m else grid[j][i]

        def count(direction):
            result = 0
            cnt = [0]*min(n, m)
            for j in direction(xrange(max(n, m))):
                c = sum(get(i, j) for i in xrange(len(cnt)))
                for i in xrange(len(cnt)):
                    if get(i, j) == 0:
                        continue
                    result += cnt[i]
                    cnt[i] += c-1
            return result
        
        n, m = len(grid), len(grid[0])
        return count(lambda x: x)+count(reversed)

Solution from kamyu104/LeetCode-Solutions · MIT