当前位置: 首页 > 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;
        }
    }
};

http://www.dtcms.com/a/101747.html

相关文章:

  • 火山引擎智能数据洞察 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
  • Python-数据处理
  • 深度剖析Spring Cloud Eureka:微服务注册与发现的终极指南 [特殊字符]
  • (C++11/C++14新特性)C++中的Lambda表达式——捕获方式和参数?值捕获和引用捕获?泛型Lambda和普通Lambda?
  • 一文解读DeepSeek大模型在政府工作中具体的场景应用
  • C++初阶知识复习 (31~45)
  • jQuery 入门案例教程
  • Ubuntu系统Docker安装失败
  • VUE如何前端控制及动态路由详细讲解
  • 日程公布| 第八届地球空间大数据与云计算前沿大会与集中学习(3号通知)
  • idea自动生成注释