Leetcode 2906. Construct Product Matrix

本文讨论了解决LeetCode题目2906中构造乘积矩阵的方法,涉及数论技巧,尤其是针对给定合数模运算的优化。作者提供了Python代码实现,并分析了其时间和空间复杂度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 解题思路

这道题其实算是一道数论题。

本来其实python的pow内置函数已经帮我们基本处理了所有的问题了,但是这里稍微做了一点复杂化操作,给出的模是12345,这是一个合数,而不是一个质数,因此并不总能保证对于任意一个数 x x x,存在另一个数 y y y使得 x y ≡ 1 ( m o d   12345 ) xy \equiv 1 (mod \ 12345) xy1(mod 12345),但是,我们只需要将 12345 12345 12345质因数分解为 12345 = 3 × 5 × 823 12345=3\times 5 \times 823 12345=3×5×823,那么,我们只需要对这三个因子进行单独考察即可。

2. 代码实现

给出python代码实现如下:

class Solution:
    def constructProductMatrix(self, grid: List[List[int]]) -> List[List[int]]:
        MOD = 12345
        # 12345 = 3*5*823
        
        n, m = len(grid), len(grid[0])
        prod, cnt = 1, defaultdict(int)
        for i in range(n):
            for j in range(m):
                val = grid[i][j]
                while val % 3 == 0:
                    cnt[3] += 1
                    val = val // 3
                while val % 5 == 0:
                    cnt[5] += 1
                    val = val // 5
                while val % 823 == 0:
                    cnt[823] += 1
                    val = val // 823
                prod = prod * val % MOD
        
        def fn(i, j):
            val = grid[i][j]
            cnt3 = cnt[3]
            while val % 3 == 0:
                cnt3 -= 1
                val = val // 3
            cnt5 = cnt[5]
            while val % 5 == 0:
                cnt5 -= 1
                val = val // 5
            cnt823 = cnt[823]
            while val % 823 == 0:
                cnt823 -= 1
                val = val // 823
            return (prod * pow(val, -1, MOD) * pow(3, cnt3, MOD) * pow(5, cnt5, MOD) * pow(823, cnt823, MOD)) % MOD
        
        return [[fn(i, j) for j in range(m)] for i in range(n)]

提交代码评测得到:耗时2361ms,占用内存50.4MB。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值