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

LeetCode算法题(Go语言实现)_23

题目

给你一个下标从 0 开始、大小为 n x n 的整数矩阵 grid ,返回满足 Ri 行和 Cj 列相等的行列对 (Ri, Cj) 的数目。
如果行和列以相同的顺序包含相同的元素(即相等的数组),则认为二者是相等的。

一、代码实现

func equalPairs(grid [][]int) int {
    n := len(grid)
    rowMap := make(map[string]int)
    
    // 统计每行的字符串出现次数
    for _, row := range grid {
        var sb strings.Builder
        for j, num := range row {
            if j > 0 {
                sb.WriteString(",")
            }
            sb.WriteString(strconv.Itoa(num))
        }
        rowMap[sb.String()]++
    }

    count := 0
    // 遍历每列并匹配行哈希
    for j := 0; j < n; j++ {
        var sb strings.Builder
        for i := 0; i < n; i++ {
            if i > 0 {
                sb.WriteString(",")
            }
            sb.WriteString(strconv.Itoa(grid[i][j]))
        }
        count += rowMap[sb.String()]
    }
    return count
}

二、算法分析

  1. 核心思路

    • 哈希映射:通过将行转换为字符串作为哈希键,统计每行的出现次数
    • 对称查询:遍历列并生成相同格式的字符串,查询哈希表实现快速匹配
  2. 关键步骤

    • 行统计阶段:将每行元素拼接为逗号分隔字符串(如"3,1,2,2")存入哈希表
    • 列匹配阶段:对每列生成相同格式字符串,累加哈希表中对应键的值
    • 去重机制:利用字符串天然的唯一性保证行列元素的严格匹配
  3. 复杂度

    指标说明
    时间复杂度O(n²)遍历行列各需O(n²)时间
    空间复杂度O(n²)哈希表存储所有行的字符串

三、图解示例

在这里插入图片描述

四、边界条件与扩展

  1. 特殊场景处理

    • 全相同矩阵:如[[1,1],[1,1]],返回4(每个行列都匹配)
    • 空矩阵:根据题意n≥1,无需处理
    • 巨型元素:字符串拼接兼容大整数,无需特殊处理
  2. 多语言实现

# Python利用元组哈希特性
def equalPairs(grid):
    row_counts = defaultdict(int)
    for row in grid:
        row_counts[tuple(row)] += 1
    
    count = 0
    n = len(grid)
    for j in range(n):
        column = tuple(grid[i][j] for i in range(n))
        count += row_counts.get(column, 0)
    return count
// Java使用行列对象哈希
public int equalPairs(int[][] grid) {
    Map<List<Integer>, Integer> map = new HashMap<>();
    int n = grid.length;
    for (int[] row : grid) {
        List<Integer> key = new ArrayList<>();
        for (int num : row) key.add(num);
        map.put(key, map.getOrDefault(key, 0) + 1);
    }
    
    int res = 0;
    for (int j = 0; j < n; j++) {
        List<Integer> col = new ArrayList<>();
        for (int i = 0; i < n; i++) 
            col.add(grid[i][j]);
        res += map.getOrDefault(col, 0);
    }
    return res;
}
  1. 算法对比
方法时间复杂度空间复杂度优势
哈希映射法O(n²)O(n²)最优时间复杂度
暴力枚举法O(n³)O(1)实现简单
矩阵压缩法O(n²)O(n)空间优化但实现复杂

五、总结与扩展

  • 数学本质:利用集合论中的笛卡尔积特性,将行列匹配转化为集合交运算
  • 工程优化:采用字符串哈希替代数组比较,减少内存占用(相比存储整型数组)
  • 扩展应用
    1. 基因序列比对:检测DNA碱基链的互补匹配
    2. 图像模式识别:匹配行列像素分布模式
    3. 推荐系统:通过用户-商品矩阵寻找行为相似行列

相关文章:

  • 9对象树(3)
  • 组合数学——排列与组合
  • 24.3 CogView3多模态生成实战:从API调优到1024高清图像生成全解析
  • 使用 Provider 和 GetX 实现 Flutter 局部刷新的几个示例
  • oracle 分组函数
  • STM32单片机入门学习——第3-4节: [2-1、2]软件安装和新建工程
  • Netty——心跳监测机制
  • 【Java 优选算法】哈希表
  • 基于springboot+vue的动漫交流与推荐平台
  • Zookeeper经典应用场景实战
  • 【GPT入门】第29课 对比不同的langchain ReAct代理的思考过程
  • C嘎嘎类里面的额函数
  • 一文详细讲解Python(详细版一篇学会Python基础和网络安全)
  • 安卓Q以下自定义文字的字体
  • LVGL Dropdown和Calendar详解
  • 机器学习 第一章 绪论
  • 算法 | 蜣螂优化算法(DBO)在无人机路径规划中的应用(附matlab源码)
  • 单机快速部署开源、免费的分布式任务调度系统——DolphinScheduler
  • VuePress 和 Docusaurus的对比
  • C# System.Net.IPAddress 使用详解
  • 商务部:“一国一策”落实对非合作“十大伙伴行动”
  • 央行行长潘功胜主持召开金融支持实体经济座谈会
  • 韩国总统选举白热化进行中,中韩青年民间交流促两国友好往来
  • 国家发改委:大部分稳就业稳经济政策将在6月底前落地
  • 林园:茅台一直是稀缺资源,股东比较有信仰,依旧看好白酒市场
  • 张宇祥已任上海闵行区委常委、副区长