leetcode每日一题-3033. 修改矩阵

题目描述:

解题思路:简单题目,思路非常直接。对列进行遍历,记录下最大值,然后再遍历一遍,把-1替换为最大值。需要注意的是进行列遍历和行遍历是不同的。

官方题解:

cpp 复制代码
class Solution {
public:
    vector<vector<int>> modifiedMatrix(vector<vector<int>>& matrix) {
        int n = matrix.size();
        int m = matrix[0].size();
        for (int j = 0; j < m; j++) {
            int zd = -1;
            for (int i = 0; i < n; i++) {
                zd = max(zd, matrix[i][j]);
            }
            for (int i = 0; i < n; i++) {
                if (matrix[i][j] == -1) {
                    matrix[i][j] = zd;
                }
            }
        }
        return matrix;
    }
};

其实还可以进一步优化。官方题解对数据进行了两次遍历,有没有办法进行一次遍历呢?事实上可以把每一列的最大值和-1的元素坐标先保存下来,然后再把元素坐标替换为相应列的最大值即可。

这样只需要遍历一次数据就可以了。

cpp 复制代码
class Solution {
public:
    // 存储坐标的结构体
    struct LOC{
        // 行坐标
        int row;
        // 列坐标
        int col;
    };
public:
    vector<vector<int>> modifiedMatrix(vector<vector<int>>& matrix) {
        // 获取行数
        int row = matrix.size();
        // 获取列数
        int col = matrix[0].size();
        // 没列最大值
        int max_value;
        // 存储每列最大值
        vector<int> max_vector;
        // 存储-1元素的坐标
        vector<LOC> loc_vector;
        // 按照列优先进行遍历
        for(int i=0;i<col; ++i)
        {
            // 假设最大值为-2
            max_value = -2;
            for(int j=0;j<row;++j)
            {
                if(max_value< matrix[j][i])
                    max_value=matrix[j][i];
                if(matrix[j][i]==-1)
                {
                    LOC tmp_loc;
                    tmp_loc.row = j;
                    tmp_loc.col = i;
                    loc_vector.push_back(tmp_loc);
                }
            }
            max_vector.push_back(max_value);
        }
        // 开始对-1的元素进行替换
        for(int i=0; i<loc_vector.size();++i)
        {
            matrix[loc_vector[i].row][loc_vector[i].col]=max_vector[loc_vector[i].col];
        }
        return matrix;

    }
};

这是一条吃饭博客,由挨踢零声赞助。学C/C++就找挨踢零声,加入挨踢零声,面试不挨踢!

相关推荐
颜酱2 小时前
队列练习系列:从基础到进阶的完整实现
javascript·后端·算法
用户5757303346242 小时前
两数之和:从 JSON 对象到 Map,大厂面试官到底在考察什么?
算法
程序猿追2 小时前
“马”上行动:手把手教你基于灵珠平台打造春节“全能数字管家”
算法
ZPC821018 小时前
docker 镜像备份
人工智能·算法·fpga开发·机器人
ZPC821018 小时前
docker 使用GUI ROS2
人工智能·算法·fpga开发·机器人
琢磨先生David18 小时前
Day1:基础入门·两数之和(LeetCode 1)
数据结构·算法·leetcode
颜酱18 小时前
栈的经典应用:从基础到进阶,解决LeetCode高频栈类问题
javascript·后端·算法
多恩Stone18 小时前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系
开发语言·c++·人工智能·python·算法·3d·aigc
生信大杂烩18 小时前
癌症中的“细胞邻域“:解码肿瘤微环境的空间密码 ——Nature Cancer 综述解读
人工智能·算法
蜡笔小马19 小时前
21.Boost.Geometry disjoint、distance、envelope、equals、expand和for_each算法接口详解
c++·算法·boost