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

天津 做网站如何给公司网站做优化

天津 做网站,如何给公司网站做优化,深圳网站建设网站制作,百度排行榜小说LCR 013. 二维区域和检索 - 矩阵不可变 给定一个二维矩阵 matrix,以下类型的多个请求: 计算其子矩形范围内元素的总和,该子矩阵的左上角为 (row1, col1) ,右下角为 (row2, col2) 。 实现 NumMatrix 类: NumMatrix(…

LCR 013. 二维区域和检索 - 矩阵不可变

给定一个二维矩阵 matrix,以下类型的多个请求:

  • 计算其子矩形范围内元素的总和,该子矩阵的左上角为 (row1, col1) ,右下角为 (row2, col2)

实现 NumMatrix 类:

  • NumMatrix(int[][] matrix) 给定整数矩阵 matrix 进行初始化
  • int sumRegion(int row1, int col1, int row2, int col2) 返回左上角 (row1, col1) 、右下角 (row2, col2) 的子矩阵的元素总和。

示例 1:
在这里插入图片描述

输入: 
["NumMatrix","sumRegion","sumRegion","sumRegion"]
[[[[3,0,1,4,2],[5,6,3,2,1],[1,2,0,1,5],[4,1,0,1,7],[1,0,3,0,5]]],[2,1,4,3],[1,1,2,2],[1,2,2,4]]
输出: 
[null, 8, 11, 12]解释:
NumMatrix numMatrix = new NumMatrix([[3,0,1,4,2],[5,6,3,2,1],[1,2,0,1,5],[4,1,0,1,7],[1,0,3,0,5]]]);
numMatrix.sumRegion(2, 1, 4, 3); // return 8 (红色矩形框的元素总和)
numMatrix.sumRegion(1, 1, 2, 2); // return 11 (绿色矩形框的元素总和)
numMatrix.sumRegion(1, 2, 2, 4); // return 12 (蓝色矩形框的元素总和)

提示:

  • m == matrix.length
  • n == matrix[i].length
  • 1 <= m, n <= 200
  • -105 <= matrix[i][j] <= 105
  • 0 <= row1 <= row2 < m
  • 0 <= col1 <= col2 < n
  • 最多调用 104sumRegion 方法

法1:暴力

**分析:**两层for循环遍历

时间复杂度 O ( n 2 ) O(n^2) O(n2)

空间复杂度 O ( 1 ) O(1) O(1)

 var NumMatrix = function(matrix) {this.matrix = matrix;
};NumMatrix.prototype.sumRegion = function(row1, col1, row2, col2) {matrix = this.matrix;let result = 0;for (let r = row1; r <= row2; r++) {for (let c = col1; c <= col2; c++) {result += matrix[r][c];}}return result
};const matrix = [[3, 0, 1, 4, 2],[5, 6, 3, 2, 1],[1, 2, 0, 1, 5],[4, 1, 0, 1, 7],[1, 0, 3, 0, 5]
];
var obj = new NumMatrix(matrix);
console.log(obj.sumRegion(2, 1, 4, 3)); // 输出 8
console.log(obj.sumRegion(1, 1, 2, 2)); // 输出 11
console.log(obj.sumRegion(1, 2, 2, 4)); // 输出 12

leetcode上通过不了

法2: 前缀和(Prefix Sum)

分析:

定义一个prefixSum ,比原本的matrix多一行多一列。

prefixSum 中,prefixSum[i][j] 表示从 (0,0)(i-1, j-1) 的区域和。

比如要计算prefixSum[3][3],也就是matrix[3][3]左上角的和。

在这里插入图片描述

28怎么来,要求matrix[3][3]左上角的和,也就是要求

28 = matrix[i - 1][j - 1]      //这个就是matrix[2][2]=1
+ this.prefixSum[i - 1][j]     //prefixSum[2][3]=matrix[2][3]左上角的和=16
+ this.prefixSum[i][j - 1] 	   //prefixSum[3][2]=matrix[3][2]左上角的和=22
- this.prefixSum[i - 1][j - 1];//prefixSum[2][2]=matrix[2][2]左上角的和=11
// 1+16+22-11=28

在这里插入图片描述

可以看出prefixSum[3][2]prefixSum[2][3]有交集prefixSum[2][2],多以最后要减去一个prefixSum[2][2],再加上maxtrix[2][2](图中绿色填充)的。

int sumRegion(int row1, int col1, int row2, int col2)

再看比如说计算sumRegion(1,1,2,2)

this.prefixSum[row2 + 1][col2 + 1] -  // prefixSum[3][3]
this.prefixSum[row1][col2 + 1] -      // prefixSum[1][3]
this.prefixSum[row2 + 1][col1] +      // prefixSum[3][1] 
this.prefixSum[row1][col1];           // prefixSum[1][1]

在这里插入图片描述

时间复杂度 O ( n ) O(n) O(n)

空间复杂度 O ( 1 ) O(1) O(1)

 var NumMatrix = function(matrix) {// 初始化 NumMatrix 类的实例属性 matrixthis.matrix = matrix;const m = matrix.length;const n = matrix[0].length;// 创建一个 m+1 x n+1 的前缀和数组 (多加一行一列是为了方便计算)this.prefixSum = Array(m + 1).fill().map(() => Array(n + 1).fill(0));// 填充前缀和数组for (let i = 1; i <= m; i++) {for (let j = 1; j <= n; j++) {this.prefixSum[i][j] = matrix[i - 1][j - 1] + this.prefixSum[i - 1][j] + this.prefixSum[i][j - 1] - this.prefixSum[i - 1][j - 1];}}    
};NumMatrix.prototype.sumRegion = function(row1, col1, row2, col2) {// 使用前缀和公式计算区域和return this.prefixSum[row2 + 1][col2 + 1] - this.prefixSum[row1][col2 + 1] - this.prefixSum[row2 + 1][col1] + this.prefixSum[row1][col1];
};
http://www.yayakq.cn/news/731954/

相关文章:

  • 网站目录管理模板下载免费红色ppt模板网站
  • 广州手机网站定制信息网络营销理论与实务
  • 宝安网站设计公司人人站cms
  • 网站文章伪原创怎么做中联网站建设
  • 企业网站备案域名可以用个人的长春做网络优化的公司
  • 建立一个网站英语建设网站不用模板可以吗
  • 网站免费网站免费app开发软件公司
  • 个人备案可以做盈利网站吗公司的网站开发费计入什么科目
  • 滁州市南谯区住房和建设局网站长沙专业网站建设公司排名
  • 网站研发品牌建设之道有哪些
  • o2o平台都有哪些网站公司悠悠我心的个人网站素材
  • 阿里云wordpress建站win2008做网站
  • 十大搜索引擎网站网站建设方案书个人
  • 专业设计网站排名next wordpress
  • 石家庄建网站挣钱优帮云2345传奇世界游戏介绍
  • 淄博做淘宝网站贵州省水利建设项目公示网站
  • 中英文外贸网站模版网站标题优化工具
  • 网站建设营销排名方案江苏泰州建设局网站
  • 在淘宝上的毕设网站代做开发公司工程部经理述职报告
  • h5商城网站怎么建立深圳网页设计公司
  • 永康网站开发公司wordpress目录扫描
  • 童装网站建设个人网站建设与实现
  • 广州企立科技做网站网站负责人信息表
  • 如何进行电商网站设计开发网站建设要学会什么
  • 网站建设小程序公众号销售网站制作公司品牌
  • 做网站需要的课程做旅游网站公司
  • 百度网站怎么用做网站每天任务及实训过程
  • 体育类网站模板flash网站设计师
  • 网站设计 教程phpcms v9 网站名称标签
  • 成都专业网站制作网站网页设计购物网站模板