2661. 找出叠涂元素 --力扣 --JAVA

题目

给你一个下标从 0 开始的整数数组 arr 和一个 m x n 的整数 矩阵 matarrmat 都包含范围 [1,m * n] 内的 所有 整数。

从下标 0 开始遍历 arr 中的每个下标 i ,并将包含整数 arr[i]mat 单元格涂色。

请你找出 arr 中在 mat 的某一行或某一列上都被涂色且下标最小的元素,并返回其下标 i

解题思路

  1. 先将元素和位置通过map进行绑定,便于后续查找;
  2. 通过双层for循环来寻找最早填充行的位置和最早填充列的位置;
  3. 同一行或同一列内以最晚填充的为准,不同行不同列以最早填充为准。

代码展示

java 复制代码
class Solution {
    public int firstCompleteIndex(int[] arr, int[][] mat) {
        int size = arr.length;
        Map<Integer,Integer> data = new HashMap<>();
        for (int i = 0; i < size; i++){
            data.put(arr[i], i);
        }
        int min = Integer.MAX_VALUE;
        //求行最小
        for (int i = 0; i < mat.length; i++){
            int max = Integer.MIN_VALUE;
            for (int j = 0; j < mat[0].length; j++){
                max = Math.max(max, data.get(mat[i][j]));
            }
            min = Math.min(min, max);
        }
        //求列最小
        for (int i = 0; i < mat[0].length; i++){
            int max = Integer.MIN_VALUE;
            for (int j = 0; j < mat.length; j++){
                max = Math.max(max, data.get(mat[j][i]));
            }
            min = Math.min(min, max);
        }
        return min;
    }
}
相关推荐
再卷也是菜18 分钟前
C++篇(21)图
数据结构·c++·算法
星轨初途23 分钟前
C++入门(算法竞赛类)
c++·经验分享·笔记·算法
没书读了1 小时前
数据结构-考前记忆清单
数据结构
灰灰勇闯IT1 小时前
KMP算法在鸿蒙系统中的应用:从字符串匹配到高效系统级开发(附实战代码)
算法·华为·harmonyos
小龙报1 小时前
【算法通关指南:数据结构和算法篇 】队列相关算法题:3.海港
数据结构·c++·算法·贪心算法·创业创新·学习方法·visual studio
csuzhucong2 小时前
一阶魔方、一阶金字塔魔方、一阶五魔方
算法
五花就是菜2 小时前
P12906 [NERC 2020] Guide 题解
算法·深度优先·图论
辞旧 lekkk2 小时前
【c++】封装红黑树实现mymap和myset
c++·学习·算法·萌新
星轨初途2 小时前
C++的输入输出(上)(算法竞赛类)
开发语言·c++·经验分享·笔记·算法
n***F8752 小时前
SpringMVC 请求参数接收
前端·javascript·算法