把矩阵0元所在行列设置为0

翻译 2012年07月14日 21:02:19

Write an algorithm such that if an element in an MxN matrix is 0, its entire row and column is set to 0

写一个算法使得把一个M*N的矩阵中0元素所在位置的行列设置为零

At first glance, this problem seems easy: just iterate through the matrix and every time we see a 0, set that row and column to 0     There’s one problem with that solution though: we will “recognize” those 0s later on in our iteration and then set their row and column to zero  Pretty soon, our entire matrix is 0s!
One way around this is to keep a second matrix which flags the 0 locations   We would then do a second pass through the matrix to set the zeros   This would take O(MN) space.Do we really need O(MN) space?     No   Since we’re going to set the entire row and column to zero, do we really need to track which cell in a row is zero?  No   We only need to know that row 2, for example, has a zero.
The code below implement this algorithm    We keep track in two  arrays all the rows with zeros and all the columns with zeros  We then make a second pass of the matrix and set a cell to zero if its row or column is zero  

void setZeros(int matrix[][],int m,int n)
{	
	int *row=(int *)malloc(m*sizeof(int));
	int *column=(int *)malloc(n*sizeof(int));
	int i,j;
	
	for(i=0;i<m;i++)
	{
		for(j=0;j<n;j++)
		{
			if (matrix[i][j]==0)
			{
				row[i]=1;
				column[j]=1;
			}
			printf("%d ",matrix[i][j]);
		}
		printf("\n");
	}

	for (i=0;i<m;i++)
	{
		for (j=0;j<n;j++)
		{
			if(row[i]==1||column[j]==1)
				matrix[i][j]=0;
			printf("%d ",matrix[i][j]);
		}
		printf("\n");
	}
}


面试题91:清除矩阵0所在行列

题目: 请编写一个算法,若MxN矩阵中某个元素为0,则将其所在的行与列清零。 给定一个MxN的int[][]矩阵(C++中为vector)mat和矩阵的阶数n,请返回完成操作后的int...
  • tianya_team
  • tianya_team
  • 2016年06月02日 09:55
  • 398

程序员面试金典: 9.1数组与字符串 7若M*N矩阵中某个元素为0,则将其所在行与列清零

#include #include using namespace std; const int MAXSIZE = 100; int matrix[MAXSIZE][MAXSIZE]; /*...
  • qingyuanluofeng
  • qingyuanluofeng
  • 2016年12月20日 16:31
  • 320

【Java】若MxN矩阵中某个元素为0, 则将其所在的行与列清零

若直接遍历整个矩阵,发现为零的元素就直接将所在行与列清零,这样做有一个陷阱,在读取已被清零的行或列时,读到的全是零,于是所在的行或列都变成零。 很快整个矩阵的所有元素都全部变为零了。 其实我们并不...
  • michellechouu
  • michellechouu
  • 2015年07月07日 21:56
  • 1661

《程序员面试金典》--清除二维数组中元素为0所在的行和列

题目描述: 请编写一个算法,若MxN矩阵中某个元素为0,则将其所在的行与列清零。 给定一个MxN的int[][]矩阵(C++中vector>)mat和矩阵的阶数n,请返回完成操作后的int[]...
  • zdplife
  • zdplife
  • 2015年09月15日 19:17
  • 791

程序员面试金典1.7:若M*N矩阵中某个元素为0,则将其所在的行与列清零

1.7:编写一个算法,若M*N矩阵中某个元素为0,则将其所在的行与列清零。 咋一看,这个问题很简单:直接遍历整个矩阵,只要发现值为0的元素,就将其所在的行与列清零。不过这种方法有个缺陷:在读取被清零...
  • jsqfengbao
  • jsqfengbao
  • 2015年08月29日 14:25
  • 1877

阿里云服务器ECS 0元拥抱云服务器 申请及使用

2014/9/10 阿里云服务器0年半年使用 通过 审核
  • xtusr113
  • xtusr113
  • 2014年09月11日 09:08
  • 914

将矩阵中值为0的元素所在的行和列设置为0, in-place O(1)space O(mn) time

将矩阵中值为0的元素所在的行和列设置为0, in-place O(1)space O(mn) time 使用O(m+n)space 的方案比较容易想到...
  • smartxxyx
  • smartxxyx
  • 2015年04月09日 20:05
  • 1567

数组中0所在行列设置为0

昨天面试的一道笔试题,一个数组中如果有0则把该行与该列都设置为0求最终结果:个人思路: public class Test {  public static void main(String ar...
  • divaid
  • divaid
  • 2017年07月11日 09:39
  • 69

矩阵清0

分析一道水题,我也就刷刷这种题了。。。 将矩阵0元所在
  • richardzrc
  • richardzrc
  • 2014年06月17日 22:47
  • 805

遇0清除矩阵行列

请编写一个算法,若N阶方阵中某个元素为0,则将其所在的行与列清零。 给定一个N阶方阵int[][](C++中为vector)mat和矩阵的阶数n,请返回完成操作后的int[][]方阵(C++中为ve...
  • u014800094
  • u014800094
  • 2016年12月27日 13:53
  • 116
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:把矩阵0元所在行列设置为0
举报原因:
原因补充:

(最多只允许输入30个字)