LeetCode 2661. First Completely Painted Row or Column

🔗 https://leetcode.com/problems/first-completely-painted-row-or-column

题目

  • 给一个 m*n 的二维数组,给一个 arr 的一纬数组
  • 元素由 [1, m * n] 组成
  • 遍历 arr,对二维数组中对应的元素进行染色
  • 返回执行到 arr 的第几个 index 的时候,二维数组的某一行或者某一列完成染色

思路

  • 建立 hash map,记录某个元素对应的二维数组的下标 x,y
  • 遍历 arr,对元素对应的行 x 进行统计,列 y 进行统计,当该行/列的统计值达到 max 时,返回 index

代码

cpp 复制代码
class Solution {
public:
    int firstCompleteIndex(vector<int>& arr, vector<vector<int>>& mat) {
        unordered_map<int, pair<int, int>> mp;
        for (int i = 0; i < mat.size(); i++) {
            for (int j = 0; j < mat[0].size(); j++) {
                mp[mat[i][j]] = make_pair(i, j);
            }
        }
        vector<int> row(mat.size()), col(mat[0].size());
        for (int i = 0; i < arr.size(); i++) {
            auto pair = mp[arr[i]];
            row[pair.first]++;
            col[pair.second]++;
            if (row[pair.first] == mat[0].size()) return i;
            if (col[pair.second] == mat.size()) return i;
        }
        return 0;
        
    }
};
相关推荐
Blossom.11829 分钟前
大模型知识蒸馏实战:从Qwen-72B到Qwen-7B的压缩艺术
大数据·人工智能·python·深度学习·算法·机器学习·pygame
海琴烟Sunshine3 小时前
leetcode 383. 赎金信 python
python·算法·leetcode
cynicme10 小时前
力扣3228——将 1 移动到末尾的最大操作次数
算法·leetcode
熬了夜的程序员10 小时前
【LeetCode】109. 有序链表转换二叉搜索树
数据结构·算法·leetcode·链表·职场和发展·深度优先
随意起个昵称10 小时前
【递归】二进制字符串中的第K位
c++·算法
mjhcsp10 小时前
C++ 循环结构:控制程序重复执行的核心机制
开发语言·c++·算法
立志成为大牛的小牛10 小时前
数据结构——四十一、分块查找(索引顺序查找)(王道408)
数据结构·学习·程序人生·考研·算法
xier_ran11 小时前
深度学习:RMSprop 优化算法详解
人工智能·深度学习·算法
地平线开发者11 小时前
不同传感器前中后融合方案简介
算法·自动驾驶
地平线开发者11 小时前
征程 6X 常见 kernel panic 问题
算法·自动驾驶