设为首页 加入收藏

TOP

Leetcode 细节实现 Set Matrix Zeroes
2015-07-20 17:35:51 来源: 作者: 【 】 浏览:1
Tags:Leetcode 细节 实现 Set Matrix Zeroes

Set Matrix Zeroes

Total Accepted: 18139 Total Submissions: 58671My Submissions

Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place.

click to show follow up.



题意:给定矩阵,如果矩阵的某个位置为0,则把那一行那一列的所有元素都置为0
思路:用两个bool数组,分别记录应该把所有元素置为0的行和列
复杂度:时间O(m*n),空间O(m+n)


void setZeroes(vector
  
    > &matrix){
	if(matrix.empty()) return ;
	int rows = matrix.size(), columns = matrix[0].size();
	vector
   
     row(rows, false); vector
    
      column(columns, false); for(int i = 0; i < rows; ++i){ for(int j = 0; j < columns; ++j){ if(matrix[i][j] == 0){ row[i] = column[j] = true; continue; } } } for(int i = 0; i < rows; ++i){ if(!row[i]) continue; for(int j = 0; j < columns; ++j){ matrix[i][j] = 0; } } for(int j = 0; j < columns; ++j){ if(!column[j]) continue; for(int i = 0; i < rows; ++i){ matrix[i][j] = 0; } } }
    
   
  




】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇NYOJ 1076 方案数量(公式 或 递.. 下一篇NYOJ 1075 (递推 + 矩阵快速幂)

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Redis 分布式锁全解 (2025-12-25 17:19:51)
·SpringBoot 整合 Red (2025-12-25 17:19:48)
·MongoDB 索引 - 菜鸟 (2025-12-25 17:19:45)
·What Is Linux (2025-12-25 16:57:17)
·Linux小白必备:超全 (2025-12-25 16:57:14)