码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • LeetCode 2352. 相等行列对


    文章目录

      • 1. 题目
      • 2. 解题

    1. 题目

    给你一个下标从 0 开始、大小为 n x n 的整数矩阵 grid ,返回满足 Ri 行和 Cj 列相等的行列对 (Ri, Cj) 的数目。

    如果行和列以相同的顺序包含相同的元素(即相等的数组),则认为二者是相等的。

    示例 1:

    在这里插入图片描述

    输入:grid = [[3,2,1],[1,7,6],[2,7,7]]
    输出:1
    解释:存在一对相等行列对:
    - (第 2 行,第 1 列):[2,7,7]
    
    • 1
    • 2
    • 3
    • 4

    示例 2:

    在这里插入图片描述

    输入:grid = [[3,1,2,2],[1,4,4,5],[2,4,2,2],[2,4,2,2]]
    输出:3
    解释:存在三对相等行列对:
    - (第 0 行,第 0 列):[3,1,2,2]
    - (第 2 行, 第 2 列):[2,4,2,2]
    - (第 3 行, 第 2 列):[2,4,2,2]
     
    提示:
    n == grid.length == grid[i].length
    1 <= n <= 200
    1 <= grid[i][j] <= 10^5
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    来源:力扣(LeetCode)
    链接:https://leetcode.cn/problems/equal-row-and-column-pairs
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    2. 解题

    • 暴力,找到首列和首行相同的数,然后再进行比较
    class Solution:
        def equalPairs(self, grid: List[List[int]]) -> int:
            n = len(grid)
            m = defaultdict(list) # v: [idx ]
            for i in range(n):
                m[grid[0][i]].append(i)
            def same(x, y):
                for i in range(n):
                    if grid[x][i] != grid[i][y]:
                        return False
                return True
            ans = 0
            for i in range(n):
                for j in m[grid[i][0]]:
                    if same(i, j):
                        ans += 1
            return ans
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    1976 ms 18.6 MB Python3

    • 更优的做法,转置后得到的新矩阵 跟原来的进行比较
    class Solution:
        def equalPairs(self, grid: List[List[int]]) -> int:
            n = len(grid)
            g2 = [[0 for i in range(n)] for j in range(n)]
            for i in range(n):
                for j in range(n):
                    g2[i][j] = grid[j][i]
            ans = 0
            for i in range(n):
                for j in range(n):
                    if g2[i] == grid[j]:
                        ans += 1
            return ans
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    404 ms 18.5 MB Python3


    我的CSDN博客地址 https://michael.blog.csdn.net/

    长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
    Michael阿明

  • 相关阅读:
    2020年Github上最牛的Java进阶教程及Java实战项目都在这里了!
    Git实战篇(快速上手精通)
    HCIA-datacom 4.3 实验三:网络地址转换配置实验
    vue-cli创建项目(详情步骤)
    【数之道 05】走进神经网络模型、机器学习的世界
    Google Earth Engine(GEE)——如何通过F-fold完成交叉验证
    React之useState hook
    倒计时5天!飞桨AI Studio星河社区x智海Mo AI大模型创意应用大赛等你来战!
    数据结构与算法设计分析——常用搜索算法
    居家必备练习题(C语言)
  • 原文地址:https://blog.csdn.net/qq_21201267/article/details/126065925
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号