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

代刷网站只做软件下载网站结构的规划与设计

代刷网站只做软件下载,网站结构的规划与设计,高邮建设局网站,备案网站查询网址73矩阵置零 题目 思路解析 收集0位置所在的行和列 然后该行全部初始化为0 该列全部初始化为0 代码 class Solution {public void setZeroes(int[][] matrix) {int m matrix.length;int n matrix[0].length;List<Integer> list1 new ArrayList<>();List<…

73矩阵置零

题目

思路解析

收集0位置所在的行和列

然后该行全部初始化为0

该列全部初始化为0

代码

class Solution {public void setZeroes(int[][] matrix) {int m = matrix.length;int n = matrix[0].length;List<Integer> list1 = new ArrayList<>();List<Integer> list2 = new ArrayList<>();for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {if (matrix[i][j] == 0) {list1.add(i);list2.add(j);}}}for (int temp : list1) {for (int i = 0; i < n; i++) {matrix[temp][i] = 0;}}for (int temp : list2) {for (int i = 0; i < m; i++) {matrix[i][temp] = 0;}}}
}

54螺旋矩阵

题目

思路解析

直接左右下左上

这样子循环遍历就好了

主要注意的是我们的边界处理问题

代码

class Solution {public List<Integer> spiralOrder(int[][] matrix) {List<Integer> ans = new ArrayList<>();if (matrix == null || matrix.length == 0 || matrix[0].length == 0) return ans;int up = 0, down = matrix.length - 1;int left = 0, right = matrix[0].length - 1;while (true) {for (int i = left; i <= right; i++) { // 左->右ans.add(matrix[up][i]);}if (++up > down) break;for (int i = up; i <= down; i++) { // 上->下ans.add(matrix[i][right]);}if (--right < left) break;for (int i = right; i >= left; i--) { // 右->左ans.add(matrix[down][i]);}if (--down < up) break;for (int i = down; i >= up; i--) { // 下->上ans.add(matrix[i][left]);}if (++left > right) break;}return ans;}
}

48旋转图像

题目

思路解析

辅助矩阵

我们clone一个矩阵辅助我们,然后根据公式计算

原地修改

如上图所示,一轮可以完成矩阵 4 个元素的旋转。因而,只要分别以矩阵左上角 1/4 的各元素为起始点执行以上旋转操作,即可完整实现矩阵旋转。

具体来看,当矩阵大小 n 为偶数时,取前 n/2 行、前 n/2 列的元素为起始点;

当矩阵大小 n 为奇数时,取前 n/2 行、前 (n+1)/2 列的元素为起始点

i=0,j=0

i=0,j=1

i=1,j=0

i=1,j=1

代码

辅助矩阵
class Solution {public void rotate(int[][] matrix) {int n = matrix.length;// 深拷贝 matrix -> tmpint[][] tmp = new int[n][];for (int i = 0; i < n; i++)tmp[i] = matrix[i].clone();// 根据元素旋转公式,遍历修改原矩阵 matrix 的各元素for (int i = 0; i < n; i++) {for (int j = 0; j < n; j++) {matrix[j][n - 1 - i] = tmp[i][j];}}}
}
原地修改
class Solution {public void rotate(int[][] matrix) {int n = matrix.length;for (int i = 0; i < n / 2; i++) {for (int j = 0; j < (n + 1) / 2; j++) {int tmp = matrix[i][j];matrix[i][j] = matrix[n - 1 - j][i];matrix[n - 1 - j][i] = matrix[n - 1 - i][n - 1 - j];matrix[n - 1 - i][n - 1 - j] = matrix[j][n - 1 - i];matrix[j][n - 1 - i] = tmp;}}}
}

240搜索二维矩阵

题目

思路解析

灵神题解-排除法

我们从右上角开始

我们先通过每行最后一个位置来排除行

行排除完之后,我们再根据列最小的位置来排除列

代码

class Solution {public boolean searchMatrix(int[][] matrix, int target) {int i = 0;int j = matrix[0].length - 1; // 从右上角开始while (i < matrix.length && j >= 0) { // 还有剩余元素if (matrix[i][j] == target) {return true; // 找到 target}if (matrix[i][j] < target) {i++; // 这一行剩余元素全部小于 target,排除} else {j--; // 这一列剩余元素全部大于 target,排除}}return false;}
}

http://www.yayakq.cn/news/105787/

相关文章:

  • 做模型网站赚钱么哪些网站可以做微商
  • 大连普兰店网站建设哈尔滨优质的建站销售价格
  • 深圳做网站公司 南山做网站如何引流
  • 免费做网站视频建筑方案ppt模板
  • 代码怎么做网站个人网页设计教程大全
  • 杭州建设项目审批网站姓名查询
  • 东莞哪个镇适合打工seo优化网页
  • 网站项目申请网站建设的十点优势
  • 那个网站制作比较好广东省 网站建站
  • 合肥做网站的网络公司白云做网站的公
  • 简单企业网站计科专业毕设做网站
  • 齐河县建设局网站深圳企业网站定制
  • 网站搜索算法建设厅的电工证
  • wap网站开发实例全国企业查询系统信息
  • 网站没有流量怎么回事thinksns网站开发
  • 如何建设自己网站首页个人做搜索网站违法吗
  • 山西笑傲网站建设微信开发者工具下载安装
  • 做网站流程图郑州做网站九零后
  • 做网站是干嘛的专业网页设计师
  • iframe wordpress做seo为什么要了解网站
  • 做网站的必备软件怎么给自己的网站设置关键词
  • 打造网站品牌wordpress直接连接数据库文件
  • 更合网站开发驻马店市住房和城乡建设局网站
  • 四川在线杭州网站优化多少钱
  • 商业网站规划深圳网站建设卓企
  • 3d网站开发成本页面跳转是什么意思
  • 国外的营销网站邯郸互联网公司
  • vps装网站管理系统做旅游宣传不错的网站
  • 做分类信息网站赚钱吗win系统安装wordpress
  • 在网站接入银联怎么做公司名称变更流程及需材料