当前位置: 首页 > news >正文

网站空白模板下载电商网站建设开发

网站空白模板下载,电商网站建设开发,天津网站建设要多少钱,海尔集团网站是怎么做的39 矩阵置零 39.1 矩阵置零解决方案 解题思路: 利用第一行和第一列标记: 使用两个标记变量,rowZero和colZero,来判断第一行和第一列是否需要置零。遍历矩阵从(1,1)开始,如果某个元素是0,则标记该行和该列…

39 矩阵置零

在这里插入图片描述

39.1 矩阵置零解决方案

解题思路

  • 利用第一行和第一列标记
    • 使用两个标记变量,rowZerocolZero,来判断第一行和第一列是否需要置零。
    • 遍历矩阵从(1,1)开始,如果某个元素是0,则标记该行和该列的第一个元素为0.
    • 最后根据标记来处理第一行和第一列。
  • 步骤
    • 遍历矩阵,将遇到0的行和列的第一个元素设置为0.
    • 遍历结束后,根据第一行和第一列的标记,置零相应的位置。
    • 最后特别处理第一行和第一列,依据rowZero和colZero来决定是否置零。
class Solution {
public:void setZeroes(vector<vector<int>>& matrix) {int m = matrix.size();int n = matrix[0].size();// 标记第一行和第一列是否需要置零bool rowZero = false;bool colZero = false;// 检查第一行是否包含0for(int i = 0 ; i < n ;i++){if(matrix[0][i] == 0){rowZero = true;break;}}// 检查第一行是否包含0for(int i = 0 ; i < m ;i++){if(matrix[i][0] == 0){colZero = true;break;}}// 用第一行和第一列来标记需要置零的行和列for(int i = 1; i < m ; i++ ){for(int j = 1; j < n ; j++){if(matrix[i][j] == 0){matrix[i][0] = 0; // 标记所在行的第一列matrix[0][j] = 0; // 标记所在列的第一行}}}for(int i = 1; i < m ; i++ ){for(int j = 1; j < n ; j++){if(matrix[i][0] == 0 || matrix[0][j] == 0){matrix[i][j] = 0;}}}// 处理第一行是否需要置零if(rowZero){for(int i = 0; i < n; i++){matrix[0][i] = 0;}}// 处理第一列是否需要置零if(colZero){for(int i = 0; i < m ; i++){matrix[i][0] = 0;}}}
};

代码解释

  • 标记第一行和第一列
    • 先通过两个标记变量rowZero和colZero来记录第一行和第一列是否需要置零。
    • 遍历整个矩阵,如果某个元素是0 ,则将其对应的第一行和第一列元素置为0,表示这一行和这一列都需要被置零。
  • 根据标记置零
    • 第二次遍历矩阵(从(1,1)开始),根据第一行和第一列的标记,把相应的元素置为0.
  • 处理第一列和第一行
    • 最后,检查rowZero和colZero,如果需要,就把第一行和第一列的所有元素置为0.

时间复杂度和空间复杂度

  • 时间复杂度 O ( m ∗ n ) O(m * n ) O(mn),其中m 和 n 是矩阵的行数和列数。我们遍历了矩阵几次,每次遍历都是 O ( m ∗ n ) O(m * n) O(mn)的时间复杂度。
  • 空间复杂度 O ( 1 O(1 O(1,因为我们只用了常数空间(除了原矩阵)。

39.2 举例说明

假设有以下矩阵:

1  2  3
4  0  6
7  8  9
  • 初始化标记

    • rowZero:用来判断第一行是否需要置零。
    • colZero:用来判断第一列是否需要置零。
      初始状态
  • rowZero = false (假设第一行不需要置零)

  • colZero = false (假设第一行不需要置零)

  • 检查第一行和第一列是否包含零

    • 检查第一行
      • 第一行是1 2 3 ,没有0,因此rowZero不变,仍然为false。
    • 检查第一列
      • 第一列是1 4 7,没有 0,因此colZero不变,仍然为false。
  • 使用第一行和第一列标记需要置零的行和列
    矩阵如下:

1  2  3
4  0  6
7  8  9
  • 遍历(1,1):值是0,因此我们将martix[1][0]martix[0][1]都置为0,表示第二行和第二列需要置零。此时矩阵变为:
1  2  3
0  0  6
7  8  9
  • 遍历 (1,2):值是 6,不需要做任何操作。
  • 遍历 (2,1):值是 7,不需要做任何操作。
  • 遍历 (2,2):值是 8,不需要做任何操作。

矩阵变为:

1  2  3
0  0  6
7  8  9
  • 根据标记置零
    • 处理第二行
      • 因为martix[1][0]0,所以整个第二行需要置零。矩阵变为:
      1  2  3
      0  0  0
      7  8  9
      
    • 处理第三例
      • 因为 matrix[0][2]0,所以整个第三列需要置零。矩阵变为:
      1  2  0
      0  0  0
      7  8  0
      
  • 处理第一行和第一列
    • 处理第一行
      • 由于rowZero = false,第一行不需要置零,因此保持不变。
    • 处理第一列
      • 由于colZero = false,第一列不需要置零,因此也保持不变。
        最终矩阵
1  2  0
0  0  0
7  8  0
http://www.mmbaike.com/news/33475.html

相关文章:

  • wordpress 禁止修订版本抖音优化
  • 自己做网站用花钱么做网站关键词优化的公司
  • 专门做高仿的网站适合女生去的培训机构
  • html5网站制作教程正规推广赚佣金的平台
  • 开封网站制作学网络营销
  • 建设网站需要租赁主机吗百度移动seo首选帝搜软件
  • 网站背景怎么设置最新网络营销方式
  • 做微课的网站有哪些沧州网站优化
  • 环球影城半年卡怎么预约青岛seo外包公司
  • wordpress设置页面访问权限简述网站内容如何优化
  • 搞定设计sem优化软件哪家好
  • java+网站开发开什么书深圳网络推广软件
  • wordpress代码分割seo工作是什么意思
  • 韩国的汽车设计网站品牌策划案
  • 物流网站怎么做推广宁波seo推广推荐
  • 郑州做网站哪家便宜seo搜索引擎是什么意思
  • 网络网站制作技巧广东最新新闻
  • 专业积分商城网站建设网络推广是干什么的
  • 怎么看网站是哪个平台做的网站建设规划书
  • wordpress分类目录url没斜杠志鸿优化设计电子版
  • 做街机棋牌上什么网站发广告企业文化标语经典
  • 平面设计大赛网站国内b2b十大平台排名
  • jsp可以做网站首页吗g3云推广靠谱吗
  • 重庆档案馆建设网站网站你应该明白我的意思吗
  • 航达建设集团有限公司网站响应式模版移动优化
  • 做的好的国外网站app引流推广方法
  • 外贸网站建设.cover深圳最好seo
  • 长沙市建设局网站百度贴吧怎么发广告
  • 有多少种做网站后台程序深圳互联网公司50强
  • 用java可以做网站吗aso推广平台