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;
    }
}
相关推荐
alphaTao2 分钟前
LeetCode 每日一题 2026/1/26-2026/2/1
算法·leetcode
向哆哆19 分钟前
构建跨端健身俱乐部管理系统:Flutter × OpenHarmony 的数据结构与设计解析
数据结构·flutter·鸿蒙·openharmony·开源鸿蒙
Christo322 分钟前
TFS-2026《Fuzzy Multi-Subspace Clustering 》
人工智能·算法·机器学习·数据挖掘
2401_8576835435 分钟前
C++中的原型模式
开发语言·c++·算法
s1hiyu1 小时前
C++动态链接库开发
开发语言·c++·算法
(❁´◡`❁)Jimmy(❁´◡`❁)1 小时前
CF2188 C. Restricted Sorting
c语言·开发语言·算法
We་ct1 小时前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
星火开发设计1 小时前
C++ 预处理指令:#include、#define 与条件编译
java·开发语言·c++·学习·算法·知识
mit6.8241 小时前
dijk|tire+floyd+dp %
算法
独自破碎E1 小时前
【总和拆分 + 双变量遍历】LCR_012_寻找数组的中心下标
数据结构·算法