1252. 奇数值单元格的数目
题目描述:
给你一个 m x n 的矩阵,最开始的时候,每个单元格中的值都是 0。另有一个二维索引数组 indices,indices[i] = [ri, ci] 指向矩阵中的某个位置,其中 ri 和 ci 分别表示指定的行和列(从 0 开始编号)。
对 indices[i] 所指向的每个位置,应同时执行下述增量操作:
- ri 行上的所有单元格,加 1 。
- ci 列上的所有单元格,加 1 。
给你 m、n 和 indices 。请你在执行完所有 indices 指定的增量操作后,返回矩阵中 奇数值单元格 的数目。
示例:
输入:m = 2, n = 3, indices = [[0,1],[1,1]] 输出:6 解释:最开始的矩阵是 [[0,0,0],[0,0,0]]。 第一次增量操作后得到 [[1,2,1],[0,1,0]]。 最后的矩阵是 [[1,3,1],[1,3,1]],里面有 6 个奇数。
解题思路:
- 每次操作都会使整一行或整一列加1,我们可以一个行数组 row[m] 与一个列数组 column[n] 来记录每一行和每一列操作的次数。
- 而对于给定 m × n 数组中的某个位置(x,y),操作次数为偶数的时候,它的值就为偶数,不计入最后奇数单元格的统计中。如示例第二步中的“2”。因此最后统计航数组 row[m] 与列数组 column[n] 时,我们只关心操作次数为奇数的行和列。
如下图所示,不考虑列的情况,我们计算操作次数为奇数的行数 odd_row 时,总的奇数值单元格应为:odd_row * n(列数);同理,不考虑行的情况,计算操作次数为奇数的列数 odd_colum 时,奇数单元格为:odd_colunm *m(行数)。但同时统计行与列时,从行的视角中看,应该剔除 odd_colum 的列;列视角同理。也即,
总数 = odd_row * (n - odd_column) + odd_column * (m - odd_row)
代码实现:
/** * @param {number} m * @param {number} n * @param {number[][]} indices * @return {number} */ var oddCells = function(m, n, indices) { let row = new Array(m).fill(0); let column = new Array(n).fill(0); for(let i=0;i<indices.length;i++){ row[indices[i][0]]++; column[indices[i][1]]++; } let odd_row = 0; for(let i=0;i<m;i++){ if(row[i]%2!==0){ odd_row++; } } let odd_column = 0; for(let i=0;i<n;i++){ if(column[i]%2!==0){ odd_column++; } } return (odd_row*(n-odd_column)+odd_column*(m-odd_row)); };
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)