Skip to content

Commit

Permalink
solutions: 3142 - Check if Grid Satisfies Conditions (Easy)
Browse files Browse the repository at this point in the history
  • Loading branch information
wingkwong committed Jun 18, 2024
1 parent 208f8b3 commit e117ae9
Showing 1 changed file with 79 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,79 @@
---
description: "Author: @wingkwong | https://leetcode.com/problems/check-if-grid-satisfies-conditions/"
tags: [Array, Matrix]
---

# 3142 - Check if Grid Satisfies Conditions (Easy)

## Problem Link

https://leetcode.com/problems/check-if-grid-satisfies-conditions/

## Problem Statement

You are given a 2D matrix `grid` of size `m x n`. You need to check if each cell `grid[i][j]` is:

- Equal to the cell below it, i.e. `grid[i][j] == grid[i + 1][j]` (if it exists).
- Different from the cell to its right, i.e. `grid[i][j] != grid[i][j + 1]` (if it exists).

Return `true` if **all** the cells satisfy these conditions, otherwise, return `false`.

**Example 1:**

**Input:** grid = [[1,0,2],[1,0,2]]

**Output:** true

**Explanation:**

All the cells in the grid satisfy the conditions.

**Example 2:**

**Input:** grid = [[1,1,1],[0,0,0]]

**Output:** false

**Explanation:**

All cells in the first row are equal.

**Example 3:**

**Input:** grid = [[1],[2],[3]]

**Output:** false

**Explanation:**

Cells in the first column have different values.

**Constraints:**

- `1 <= n, m <= 10`
- `0 <= grid[i][j] <= 9`

## Approach 1: Brute Force

Iterate over each cell to check if the conditions can be satisified.

- Time Complexity: $O(n * m)$ where $n$ is the number of rows and $m$ is the number of columns
- Space Complexity: $O(1)$

<Tabs>
<TabItem value="py" label="Python">
<SolutionAuthor name="@wingkwong"/>

```py
class Solution:
def satisfiesConditions(self, grid: List[List[int]]) -> bool:
n, m = len(grid), len(grid[0])
for i in range(n):
for j in range(m):
if i < n - 1 and grid[i][j] != grid[i + 1][j]: return False
if j < m - 1 and grid[i][j] == grid[i][j + 1]: return False
return True
```

</TabItem>
</Tabs>

0 comments on commit e117ae9

Please sign in to comment.