πDay 3. Rotten Oranges π§
The problem can be found at the following link: Question Link
π‘ Problem Description:
Given a matrix mat[][] of size n Γ m, where each cell in the matrix can contain:
- 0 β Empty cell 
- 1 β Fresh orange 
- 2 β Rotten orange 
A rotten orange at position (i, j) can rot adjacent fresh oranges (up, down, left, right) in one unit of time. The task is to find the minimum time required to rot all fresh oranges. If it's impossible to rot all oranges, return -1.
π Example Walkthrough:
Example 1:
Input:
mat[][] = [
  [0, 1, 2],
  [0, 1, 2],
  [2, 1, 1]
]Output:
1Explanation:
Oranges at positions (0,2), (1,2), and (2,0) will rot adjacent oranges in one unit of time.
Example 2:
Input:
mat[][] = [[2, 2, 0, 1]]Output:
-1Explanation:
Oranges at (0,0) and (0,1) cannot rot the orange at (0,3), so it's impossible.
Example 3:
Input:
mat[][] = [
  [2, 2, 2],
  [0, 2, 0]
]Output:
0Explanation:
There are no fresh oranges, so the answer is 0.
Constraints
- $1 \leq n, m \leq 500$ 
- $1 β€ mat[0].size() β€ 500$ 
- mat[i][j]β {0, 1, 2}
π― My Approach:
Single Queue (BFS)
Algorithm Steps:
- Multi-source BFS: - Traverse the matrix to push all rotten orange coordinates into a queue. 
- Also, count the number of fresh oranges. 
 
- Level-by-Level Processing: - For each time unit, process all the oranges in the queue. 
- For each rotten orange, try to rot its adjacent fresh oranges (up, down, left, right). 
- If at least one orange is rotted during that level, increment the time counter. 
 
- Termination: - If after the BFS there are still fresh oranges left, return -1. 
- Otherwise, return the total time elapsed. 
 
Rotten Oranges: Minimum Time to Rot All Oranges
π Time and Auxiliary Space Complexity
- Expected Time Complexity: $(O(n \times m))$, since each cell (orange) in the mat is processed at most once during the BFS traversal. 
- Expected Auxiliary Space Complexity: $(O(n \times m))$, as in the worst case, the queue may contain all the cells simultaneously. 
Code (C++)
class Solution {
public:
    int orangesRotting(vector<vector<int>>& a) {
        int n = a.size(), m = a[0].size(), t = 0, f = 0;
        queue<pair<int,int>> q;
        for(int i = 0; i < n; i++)
            for(int j = 0; j < m; j++){
                if(a[i][j] == 2) q.push({i, j});
                else if(a[i][j] == 1) f++;
            }
        if(!f) return 0;
        int d[4][2] = {{1,0}, {-1,0}, {0,1}, {0,-1}};
        while(!q.empty()){
            int sz = q.size();
            bool ch = false;
            while(sz--){
                auto p = q.front(); q.pop();
                int i = p.first, j = p.second;
                for(auto &dir : d){
                    int x = i + dir[0], y = j + dir[1];
                    if(x < 0 || y < 0 || x >= n || y >= m || a[x][y] != 1) continue;
                    a[x][y] = 2; q.push({x,y}); f--; ch = true;
                }
            }
            if(ch) t++;
        }
        return f ? -1 : t;
    }
};Code (Java)
class Solution {
    public int orangesRotting(int[][] a) {
        int n = a.length, m = a[0].length, f = 0, t = 0;
        Queue<int[]> q = new LinkedList<>();
        for (int i = 0; i < n; i++)
            for (int j = 0; j < m; j++) {
                if (a[i][j] == 2)
                    q.add(new int[]{i, j});
                else if (a[i][j] == 1)
                    f++;
            }
        if (f == 0) return 0;
        int[][] d = {{1, 0}, {-1, 0}, {0, 1}, {0, -1}};
        while (!q.isEmpty()) {
            int sz = q.size();
            boolean ch = false;
            for (int k = 0; k < sz; k++) {
                int[] p = q.poll();
                int i = p[0], j = p[1];
                for (int[] dir : d) {
                    int x = i + dir[0], y = j + dir[1];
                    if (x < 0 || y < 0 || x >= n || y >= m || a[x][y] != 1)
                        continue;
                    a[x][y] = 2;
                    q.add(new int[]{x, y});
                    f--;
                    ch = true;
                }
            }
            if (ch) t++;
        }
        return f == 0 ? t : -1;
    }
}Code (Python)
from collections import deque
class Solution:
    def orangesRotting(self, a):
        n, m, f, t = len(a), len(a[0]), 0, 0
        q = deque()
        for i in range(n):
            for j in range(m):
                if a[i][j] == 2:
                    q.append((i, j))
                elif a[i][j] == 1:
                    f += 1
        if not f: return 0
        d = [(1,0),(-1,0),(0,1),(0,-1)]
        while q:
            sz, ch = len(q), False
            for _ in range(sz):
                i, j = q.popleft()
                for di, dj in d:
                    x, y = i + di, j + dj
                    if x < 0 or y < 0 or x >= n or y >= m or a[x][y] != 1:
                        continue
                    a[x][y] = 2
                    q.append((x, y))
                    f -= 1
                    ch = True
            if ch: t += 1
        return t if f == 0 else -1π― Contribution and Support:
For discussions, questions, or doubts related to this solution, feel free to connect on LinkedIn: Any Questions. Letβs make this learning journey more collaborative!
β If you find this helpful, please give this repository a star! β
πVisitor Count
Last updated