73. Set Matrix Zeros

2024-09-07 14:58
文章标签 set 73 matrix zeros

本文主要是介绍73. Set Matrix Zeros,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目:

解答:

提供了两种解题思路:

第一种,使用两个数组,分别标记每一行、每一列是否有0的存在,然后再去更新二维数组。

第二种,使用两个变量brow,bcol分别标记第0行,第0列是否存在0,然后使用每一行、每一列的第一个单元存储是否该行、该列存在0.

代码:

class Solution {
public:// 方法一void setZeroes(vector<vector<int>>& matrix) {if(matrix.empty())  return;int row = matrix.size(), col = matrix[0].size();vector<int> vecrow(row,0);vector<int> veccol(col,0);for(int i = 0;i < row; ++i){for(int j = 0;j < col; ++j){if(matrix[i][j] == 0){vecrow[i] = 1;break;}}}for(int i = 0;i < col; ++i){for(int j = 0;j < row; ++j){if(matrix[j][i] == 0){veccol[i] = 1;break;}}}for(int i = 0;i < row; ++i){for(int j = 0;j < col; ++j){if(vecrow[i] || veccol[j])matrix[i][j] = 0;}}return ;}// 方法二void setZeroes(vector<vector<int>>& matrix) {int row = matrix.size(), col = matrix[0].size();bool brow0 = false, bcol0 = false;for(int i = 0;i < row; ++i){if(matrix[i][0] == 0){brow0 = true;break;}}for(int i = 0;i < col; ++i){if(matrix[0][i] == 0){bcol0 = true;break;}}for(int i = 1;i < row; ++i){for(int j = 1;j < col; ++j){if(matrix[i][j] == 0){matrix[i][0] = 0;break;}}}for(int i = 1;i < col; ++i){for(int j = 1;j < row; ++j){if(matrix[j][i] == 0){matrix[0][i] = 0;break;}}}for(int i = 1;i < row; ++i){for(int j = 1;j < col; ++j){if(matrix[i][0] == 0 || matrix[0][j] == 0)matrix[i][j] = 0;}}cout << brow0 << " " << bcol0 << endl;if(brow0){for(int i = 0;i < row; ++i){matrix[i][0] = 0;}}if(bcol0){for(int i = 0;i < col; ++i){matrix[0][i] = 0;}}}
};

更新会同步在我的网站更新(https://zergzerg.cn/notes/webnotes/leetcode/index.html)

这篇关于73. Set Matrix Zeros的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1145378

相关文章

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

shell中set -u、set -x、set -e的使用

《shell中set-u、set-x、set-e的使用》本文主要介绍了shell中set-u、set-x、set-e的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录✅ 1. set -u:防止使用未定义变量 作用: 示例:❌ 报错示例输出:✅ 推荐使用场景:✅ 2. se

MySQL中FIND_IN_SET函数与INSTR函数用法解析

《MySQL中FIND_IN_SET函数与INSTR函数用法解析》:本文主要介绍MySQL中FIND_IN_SET函数与INSTR函数用法解析,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一... 目录一、功能定义与语法1、FIND_IN_SET函数2、INSTR函数二、本质区别对比三、实际场景案例分

Nginx指令add_header和proxy_set_header的区别及说明

《Nginx指令add_header和proxy_set_header的区别及说明》:本文主要介绍Nginx指令add_header和proxy_set_header的区别及说明,具有很好的参考价... 目录Nginx指令add_header和proxy_set_header区别如何理解反向代理?proxy

poj 3050 dfs + set的妙用

题意: 给一个5x5的矩阵,求由多少个由连续6个元素组成的不一样的字符的个数。 解析: dfs + set去重搞定。 代码: #include <iostream>#include <cstdio>#include <set>#include <cstdlib>#include <algorithm>#include <cstring>#include <cm

Collection List Set Map的区别和联系

Collection List Set Map的区别和联系 这些都代表了Java中的集合,这里主要从其元素是否有序,是否可重复来进行区别记忆,以便恰当地使用,当然还存在同步方面的差异,见上一篇相关文章。 有序否 允许元素重复否 Collection 否 是 List 是 是 Set AbstractSet 否

论文翻译:ICLR-2024 PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS

PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS https://openreview.net/forum?id=KS8mIvetg2 验证测试集污染在黑盒语言模型中 文章目录 验证测试集污染在黑盒语言模型中摘要1 引言 摘要 大型语言模型是在大量互联网数据上训练的,这引发了人们的担忧和猜测,即它们可能已

多路转接之select(fd_set介绍,参数详细介绍),实现非阻塞式网络通信

目录 多路转接之select 引入 介绍 fd_set 函数原型 nfds readfds / writefds / exceptfds readfds  总结  fd_set操作接口  timeout timevalue 结构体 传入值 返回值 代码 注意点 -- 调用函数 select的参数填充  获取新连接 注意点 -- 通信时的调用函数 添加新fd到

[论文笔记]LLM.int8(): 8-bit Matrix Multiplication for Transformers at Scale

引言 今天带来第一篇量化论文LLM.int8(): 8-bit Matrix Multiplication for Transformers at Scale笔记。 为了简单,下文中以翻译的口吻记录,比如替换"作者"为"我们"。 大语言模型已被广泛采用,但推理时需要大量的GPU内存。我们开发了一种Int8矩阵乘法的过程,用于Transformer中的前馈和注意力投影层,这可以将推理所需

Android set Tag, findViewWithTag使用

设置了tag为“principal”的view ImageView principal = (ImageView) findViewById(R.id.imagen_home_0);principal.setTag("principal"); 在其它地方获取,获取已经设置了tag为“principal”的view LayoutInflater inflater = LayoutInflate