当前位置:   article > 正文

Leetcode 73题:矩阵置零(难度:中等)(C#)_leetcode第73题c语言

leetcode第73题c语言

做算法想要提高,就要多思考,多写代码,多做,并且看到题时先不要看别人的解析,先自己琢磨琢磨,然后再看别人的解析,这样会比较好的锻炼自己的思维能力。

题目:

给定一个 m x n 的矩阵,如果一个元素为 ,则将其所在行和列的所有元素都设为 0 。请使用 原地 算法

算法思路:如果检查到有元素0,我们需要把这个元素所在的行和列都变成0,所以我们保存行和列的信息,这里我们使用两个bool类型的数组进行保存,也就是把0所在的行和列都为true,之后再次遍历时为true的变为0,其他的数,遍历时直接跳过,时间复杂度还算可以,因为创建了两个bool数组,所以空间复杂度可能会稍微高一些。

具体代码:

  1. public class Solution {
  2. public void SetZeroes(int[][] matrix) {
  3. int m = matrix.Length;
  4. int n = matrix[0].Length;
  5. //设置两个标记数组
  6. //标记行
  7. bool[] row = new bool[m];
  8. //标记列
  9. bool[] col = new bool[n];
  10. //循环遍历矩阵 记录0出现的位置
  11. //用标记数组进行标记
  12. for (int i = 0; i < m; i++)
  13. {
  14. for (int j = 0; j < n; j++)
  15. {
  16. if (matrix[i][j]==0)
  17. {
  18. row[i] = col[j] = true;
  19. }
  20. }
  21. }
  22. for (int i = 0; i < m; i++)
  23. {
  24. for (int j = 0; j < n; j++)
  25. {
  26. if (row[i]||col[j])
  27. {
  28. matrix[i][j] = 0;
  29. }
  30. }
  31. }
  32. }
  33. }

希望能和大家一起进步,加油,打工人

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/羊村懒王/article/detail/257048
推荐阅读
相关标签
  

闽ICP备14008679号