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;
        
    }
};
相关推荐
散峰而望11 分钟前
C++数组(一)(算法竞赛)
c语言·开发语言·c++·算法·github
自然常数e36 分钟前
深入理解指针(1)
c语言·算法·visual studio
WWZZ202539 分钟前
快速上手大模型:深度学习13(文本预处理、语言模型、RNN、GRU、LSTM、seq2seq)
人工智能·深度学习·算法·语言模型·自然语言处理·大模型·具身智能
Christo31 小时前
AAAI-2024《Multi-Class Support Vector Machine with Maximizing Minimum Margin》
人工智能·算法·机器学习·支持向量机·数据挖掘
元亓亓亓2 小时前
LeetCode热题100--79. 单词搜索
算法·leetcode·职场和发展
司铭鸿3 小时前
化学式解析的算法之美:从原子计数到栈的巧妙运用
linux·运维·服务器·算法·动态规划·代理模式·哈希算法
2501_941143733 小时前
缓存中间件Redis与Memcached在高并发互联网系统优化与实践经验分享
leetcode
ekprada3 小时前
DAY 18 推断聚类后簇的类型
算法·机器学习·支持向量机
生信大表哥3 小时前
Python单细胞分析-基于leiden算法的降维聚类
linux·python·算法·生信·数信院生信服务器·生信云服务器
玫瑰花店4 小时前
万字C++中锁机制和内存序详解
开发语言·c++·算法