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

相关文章

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

[Day 73] 區塊鏈與人工智能的聯動應用:理論、技術與實踐

AI在健康管理中的應用實例 1. 引言 隨著健康管理需求的提升,人工智能(AI)在該領域的應用越來越普遍。AI可以幫助醫療機構提升效率、精準診斷疾病、個性化治療方案,以及進行健康數據分析,從而改善病患的健康狀況。這篇文章將探討AI如何應用於健康管理,並通過具體代碼示例說明其技術實現。 2. AI在健康管理中的主要應用場景 個性化健康建議:通過分析用戶的健康數據,如飲食、運動、睡眠等,AI可

C++ STL关联容器Set与集合论入门

1. 简介 Set(集合)属于关联式容器,也是STL中最实用的容器,关联式容器依据特定的排序准则,自动为其元素排序。Set集合的底层使用一颗红黑树,其属于一种非线性的数据结构,每一次插入数据都会自动进行排序,注意,不是需要排序时再排序,而是每一次插入数据的时候其都会自动进行排序。因此,Set中的元素总是顺序的。 Set的性质有:数据自动进行排序且数据唯一,是一种集合元素,允许进行数学上的集合相

Eclipse或MyEclipse中Java Working Set管理项目

随着学习JAVA的时间的越来越久,项目也越来越多,Eclipse或MyEclipse界面中显示一堆! 每次工作使用到的项目肯定不会太多...... 每次从这么大数量的工程当中找到自己要使用的, 必须大规模的滚动滚动条...... 图片一   Project Explorer中:    图片二:Package Explorer中: 这样就好找很多了,分类放!

STL set整理

#include<set>#include<cstdio>#include<iterator>#include<iostream>#include<algorithm>using namespace std;//set 集合的操作//multisetset<int>Set1;set<int>Set2;set<int>Set3;/*begin() 返回指向第一个元素的迭代器