mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-11 02:58:13 +08:00
40 lines
2.0 KiB
HTML
40 lines
2.0 KiB
HTML
|
<p>Given a <strong>0-indexed</strong> 2D integer matrix <code><font face="monospace">grid</font></code><font face="monospace"> </font>of size <code>n * m</code>, we define a <strong>0-indexed</strong> 2D matrix <code>p</code> of size <code>n * m</code> as the <strong>product</strong> matrix of <code>grid</code> if the following condition is met:</p>
|
||
|
|
||
|
<ul>
|
||
|
<li>Each element <code>p[i][j]</code> is calculated as the product of all elements in <code>grid</code> except for the element <code>grid[i][j]</code>. This product is then taken modulo <code><font face="monospace">12345</font></code>.</li>
|
||
|
</ul>
|
||
|
|
||
|
<p>Return <em>the product matrix of</em> <code><font face="monospace">grid</font></code>.</p>
|
||
|
|
||
|
<p> </p>
|
||
|
<p><strong class="example">Example 1:</strong></p>
|
||
|
|
||
|
<pre>
|
||
|
<strong>Input:</strong> grid = [[1,2],[3,4]]
|
||
|
<strong>Output:</strong> [[24,12],[8,6]]
|
||
|
<strong>Explanation:</strong> p[0][0] = grid[0][1] * grid[1][0] * grid[1][1] = 2 * 3 * 4 = 24
|
||
|
p[0][1] = grid[0][0] * grid[1][0] * grid[1][1] = 1 * 3 * 4 = 12
|
||
|
p[1][0] = grid[0][0] * grid[0][1] * grid[1][1] = 1 * 2 * 4 = 8
|
||
|
p[1][1] = grid[0][0] * grid[0][1] * grid[1][0] = 1 * 2 * 3 = 6
|
||
|
So the answer is [[24,12],[8,6]].</pre>
|
||
|
|
||
|
<p><strong class="example">Example 2:</strong></p>
|
||
|
|
||
|
<pre>
|
||
|
<strong>Input:</strong> grid = [[12345],[2],[1]]
|
||
|
<strong>Output:</strong> [[2],[0],[0]]
|
||
|
<strong>Explanation:</strong> p[0][0] = grid[0][1] * grid[0][2] = 2 * 1 = 2.
|
||
|
p[0][1] = grid[0][0] * grid[0][2] = 12345 * 1 = 12345. 12345 % 12345 = 0. So p[0][1] = 0.
|
||
|
p[0][2] = grid[0][0] * grid[0][1] = 12345 * 2 = 24690. 24690 % 12345 = 0. So p[0][2] = 0.
|
||
|
So the answer is [[2],[0],[0]].</pre>
|
||
|
|
||
|
<p> </p>
|
||
|
<p><strong>Constraints:</strong></p>
|
||
|
|
||
|
<ul>
|
||
|
<li><code>1 <= n == grid.length <= 10<sup>5</sup></code></li>
|
||
|
<li><code>1 <= m == grid[i].length <= 10<sup>5</sup></code></li>
|
||
|
<li><code>2 <= n * m <= 10<sup>5</sup></code></li>
|
||
|
<li><code>1 <= grid[i][j] <= 10<sup>9</sup></code></li>
|
||
|
</ul>
|