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

有个性的个人网站为什么我的网站百度搜不到

有个性的个人网站,为什么我的网站百度搜不到,太原再次发出通告,最优惠的建设网站建设这是一道难度为中等的题目#xff0c;让我们来看看题目描述#xff1a; 给定一个 _m_ x _n_ 的矩阵#xff0c;如果一个元素为 0 #xff0c;则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 提示#xff1a; m matrix.lengthn matrix[0].length1 m, n …这是一道难度为中等的题目让我们来看看题目描述 给定一个 _m_ x _n_ 的矩阵如果一个元素为 0 则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 提示 m matrix.lengthn matrix[0].length1 m, n 200- 2 31 2^{31} 231 matrix[i][j] 2 31 2^{31} 231 - 1 题解 class Solution {public void setZeroes(int[][] matrix) {int m matrix.length; // 获取矩阵的行数int n matrix[0].length; // 获取矩阵的列数boolean[] row new boolean[m]; // 记录需要置零的行boolean[] col new boolean[n]; // 记录需要置零的列// 第一遍遍历矩阵标记所有含有 0 的行和列for(int i 0; i m; i){for(int j 0; j n; j){if(matrix[i][j] 0){ row[i] true; // 标记该行需要置零col[j] true; // 标记该列需要置零}}}// 第二遍遍历矩阵根据标记的行和列将相应元素置零for(int i 0; i m; i){for(int j 0; j n; j){if(row[i] || col[j]){ // 如果当前行或列被标记为需要置零matrix[i][j] 0; // 置零操作}}}} } 解题思路 1. 题目分析 给定一个 m × n 的矩阵如果某个元素为 0则需要将它所在的整行和整列的所有元素都设为 0。要求在原矩阵上直接修改不能使用额外的矩阵存储修改后的数据。 2. 解法思路 第一步标记所有需要置零的行和列 用两个数组 row[] 和 col[] 分别记录哪些行和列需要置零。 遍历矩阵如果遇到 matrix[i][j] 0就将 row[i] 和 col[j] 标记为 true表示该行或该列需要全部置零。 第二步遍历矩阵根据标记进行置零 再次遍历矩阵如果 row[i] 为 true 或 col[j] 为 true说明该位置 matrix[i][j] 需要置零。 3. 复杂度分析 时间复杂度O(m × n) 需要两次遍历整个矩阵时间复杂度为 O(m × n)符合题目要求。 空间复杂度O(m n) 额外使用了 row[] 和 col[] 两个数组空间复杂度为 O(m n)。 4. 进阶优化 如果希望减少额外空间使用可以利用矩阵的第一行和第一列来存储这些标记而不使用额外的 row[] 和 col[] 数组进而将空间复杂度优化为 O(1)。 问题与解答 [NOTE] 问题1 if(row[i] || col[j])这一句我有一点不懂为什么要么行或列被标记就会被置0呢 解答 这个 if(row[i] || col[j]) 条件的作用是如果当前元素所在的行 i 或列 j 需要置零则将该元素 matrix[i][j] 置为 0。 为什么这样判断 想象一下矩阵的置零规则 如果一个元素 matrix[i][j] 0那么它所在的整行 和 整列 都要变成 0。在第一遍遍历矩阵时我们用 row[i] 记录第 i 行是否需要全部变 0用 col[j] 记录第 j 列是否需要全部变 0。因此在第二遍遍历时 如果 row[i] true说明该行有一个元素原本是 0所以整行要变 0当前元素 matrix[i][j] 也必须变 0。如果 col[j] true说明该列有一个元素原本是 0所以整列要变 0当前元素 matrix[i][j] 也必须变 0。只要满足任意一个条件 (row[i] 或 col[j])当前元素 matrix[i][j] 必须变成 0。 举例分析 示例 1 输入矩阵 [[1, 1, 1],[1, 0, 1],[1, 1, 1] ]第一遍标记 row[] 和 col[] row [false, true, false] // 第 1 行索引 1需要置零 col [false, true, false] // 第 1 列索引 1需要置零第二遍遍历并置零应用 if(row[i] || col[j]) [[1, 0, 1], // 因为 col[1] true第二列所有元素变 0[0, 0, 0], // 因为 row[1] true整行变 0[1, 0, 1] // 因为 col[1] true第二列所有元素变 0 ]总结 row[i] 记录行是否要变 0col[j] 记录列是否要变 0。if(row[i] || col[j]) 的含义是 如果这一行之前有 0则当前行的所有元素都要变 0。如果这一列之前有 0则当前列的所有元素都要变 0。如果当前行或列任意一个需要变 0那么 matrix[i][j] 也必须变 0。 这样就符合题目的要求用 两次遍历 实现 原地置零。
http://www.zqtcl.cn/news/461263/

相关文章:

  • 企业网站每年的费用钢筋网片每平米重量
  • 做网站是属火的职业吗苏州网站建设信息网络
  • 怎么自己建一个论坛网站如何做中国古城的网站
  • 做网站表格网站建设综合实训案例
  • vs2012 网站开发wordpress好看的页面跳转
  • 阿里去要企业网站建设方案书小程序开发 杭州
  • 微信公众号文档网站开发与优化课程总结
  • 网站建设网课海东营销网站建设公司
  • 仿站工具教程视频宣传片免费模板
  • 美食网站建设项目分析报告莱芜都市网人才招聘
  • js做网站福田网站设计公司
  • 郑州做网站好长春市建设工程信息网站
  • 题库网站怎么做做网站文件夹都起什么名字
  • 河南网站怎么备案东台市住房和建设局网站
  • 有什么手机做网站的asp.net网站安全
  • 怎么做查询网站后台做爰的视频网站
  • 迪虎科技网站建设国际市场那个app可以看
  • 怎么做跳转不影响原网站排名wordpress添加邮箱设置
  • 网站内容规范外贸电商怎么做
  • 郑州做网站齿轮wordpress 文章h标签美化
  • 建设银行网站怎么修改手机号码吗网站建设怎样容易
  • 网站建设风险管理计划书户外媒体网站建设免费
  • 学到什么程度可以做网站网站维护的要求包括
  • 泉州网站设计平台南阳响应式网站
  • 阿里云 企业网站选哪种推广普通话的文字内容
  • 广州市南沙建设局网站中山建网站咨询电话
  • 怎么创建网站快捷方式网络服务器搭建配置与管理 下载
  • 现在什么类型网站没有人做wordpress get_categories()
  • 石家庄网站推广优化闲鱼网络营销方式
  • 精诚时代 网站谁做的北京网站设计必看刻