前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【算法】奇数值单元格的数目

【算法】奇数值单元格的数目

作者头像
lomtom
发布2022-11-11 16:01:57
2930
发布2022-11-11 16:01:57
举报
文章被收录于专栏:博思奥园

作者:lomtom 个人网站:lomtom.cn 你的支持就是我最大的动力。

题目难度:简单[1]

题目描述:

给你一个 m x n 的矩阵,最开始的时候,每个单元格中的值都是 0。

另有一个二维索引数组 indices,indices[i] = [ri, ci] 指向矩阵中的某个位置,其中 ri 和 ci 分别表示指定的行和列(从 0 开始编号)。 对 indices[i] 所指向的每个位置,应同时执行下述增量操作:

  • ri 行上的所有单元格,加 1 。
  • ci 列上的所有单元格,加 1 。
  • 给你 m、n 和 indices 。请你在执行完所有 indices 指定的增量操作后,返回矩阵中 奇数值单元格 的数目。

测试用例:

示例 1

输入: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 个奇数。

示例 2:

输入:m = 2, n = 2, indices = [[1,1],[0,0]] 输出:0 解释:最后的矩阵是 [[2,2],[2,2]],里面没有奇数。

限制及提示:

1 <= m, n <= 50 1 <= indices.length <= 100 0 <= ri < m 0 <= ci < n

解题分析及思路:

由于这一题数据量比较小,那么直接暴力模拟直接接可以A掉这道题。

那么有什么方法可以优化一下呢?

根据题目我们可以得知,对于m * n 的二维数组在位置[row,col]的的值是等于该行row增加的数与该列col增加的数的总和,所以我们只需统计每一行和每一列增加的数,然后最后再对某一个位置进行计算即可。

统计时,我们只需判断该位置的值是不是奇数即可。

为了优化计算速度,我们可以把需要计算的位置换成位计算。

代码分析:

定义行、列数组分别保存该行需要增加的数和该列需要增加的数。

代码语言:javascript
复制
rows := make([]int, m)
cols := make([]int, n)
for index := range indices {
    rows[indices[index][0]]++
    cols[indices[index][1]]++
}

通过统计某一位置的值(row + col)是否为奇数即可。

代码语言:javascript
复制
for _, row := range rows {
    for _, col := range cols {
        ans += (row + col) % 2
    }
}

计算换成位计算。

代码语言:javascript
复制
rows := make([]int, m)
cols := make([]int, n)
for index := range indices {
    rows[indices[index][0]] ^= 1
    cols[indices[index][1]] ^= 1
}

for _, row := range rows {
    for _, col := range cols {
        ans += (row + col) & 1
    }
}

最后代码:奇数值单元格的数目[2]

复杂度:

  • 时间复杂度:O(m * n)
  • 空间复杂度:O(m + n)

执行结果:

  • 执行用时:0 ms, 在所有 Go 提交中击败了100.00%的用户
  • 内存消耗:2.3 MB, 在所有 Go 提交中击败了90.91%的用户

引用

[1]

奇数值单元格的数目: https://leetcode.cn/problems/cells-with-odd-values-in-a-matrix/

[2]

代码: https://github.com/lomtom/algorithm-go/blob/main/leetcode/1252奇数值单元格的数目_test.go

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-07-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 博思奥园 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 引用
相关产品与服务
腾讯云代码分析
腾讯云代码分析(内部代号CodeDog)是集众多代码分析工具的云原生、分布式、高性能的代码综合分析跟踪管理平台,其主要功能是持续跟踪分析代码,观测项目代码质量,助力维护团队卓越代码文化。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档