当前位置: 首页 > news >正文

【力扣hot100题】(017)矩阵置零

还是挺简单的,使用哈希表记录需要置换的行列即可,这样就可以避免重复节省时间。

class Solution {
public:
    void setZeroes(vector<vector<int>>& matrix) {
        unordered_set<int> row;
        unordered_set<int> line;
        for(int i=0;i<matrix.size();i++) for(int j=0;j<matrix[0].size();j++) if(matrix[i][j]==0){
            row.insert(i);
            line.insert(j);
        }
        for(auto it=row.begin();it!=row.end();it++){
            for(int i=0;i<matrix[0].size();i++) matrix[*it][i]=0;
        }
        for(auto it=line.begin();it!=line.end();it++){
            for(int i=0;i<matrix.size();i++) matrix[i][*it]=0;
        }
    }
};

看了答案有一种很好的思路,大大缩小空间复杂度,直接用第一行和第一列记录此行/此列要不要归零,因为如果要归零,那么第一行/第一列的这个位置也会归零,非常巧妙。

这个思路还是蛮有难度的,写了半天看答案才写出来。

class Solution {
public:
    void setZeroes(vector<vector<int>>& matrix) {
        bool col0=0;
        for(int i=0;i<matrix.size();i++){
            if(matrix[i][0]==0) col0=1;
            for(int j=1;j<matrix[0].size();j++){
                if(matrix[i][j]==0) matrix[0][j]=matrix[i][0]=0;
            }
        }
        for(int i=matrix.size()-1;i>=0;i--){
            for(int j=matrix[0].size()-1;j>0;j--){
                if(matrix[i][0]==0||matrix[0][j]==0) matrix[i][j]=0;
            }
            if(col0==1) matrix[i][0]=0;
        }
    }
};

相关文章:

  • 火山引擎智能数据洞察 ChatBI 适配 DeepSeek-R1 及 DeepSeek-V3
  • 【商城实战(75)】数据分析指标体系搭建:从0到1的技术指南
  • 基于Halcon仿VM流程列表的执行效果
  • 深入解析MapReduce工作流程:从核心原理到实战优化
  • 第五十二章 Spring之再进一步——Boot
  • 深度神经网络全解析:原理、结构与方法对比
  • MySQL-复制表的两种常见方式
  • AI日报 - 2025年03月28日
  • c++ - 右击一个cpp文件,但是编译菜单项是灰的
  • 【Ubuntu常用命令】
  • 【开题报告+论文+源码】基于SSM的智能驾校预约管理系统
  • leetcode160.相交链表
  • Three.js 实现四元数(Quaternion)与常用运算
  • 树莓派使用USB摄像头与TFLite实现目标检测的完整指南
  • 开源模型应用落地-glm模型小试-glm-4-9b-chat-vLLM集成(四)
  • 基于 Trae 的超轻量级前端架构设计与性能优化实践
  • 基于Flask的跨境电商头程预警分析系统
  • XRP杠杆风暴来袭:XBIT引领潮流,解析DEX抗风险体系
  • ShardingSphere
  • QT第六课------QT界面优化------QSS
  • 公司的网站建设公司/关键词优化排名费用
  • wordpress的站点地图/爱站网怎么使用
  • 辽宁最好的男科医院/网站seo技术
  • 免费学服装设计的网站/网络营销方式对比分析
  • 天天联盟广告网站如何做/营销网络推广
  • 深圳网络专科网站建设/免费b站推广网站