forked from spandey1296/Learn-Share-Hacktoberfest2021
-
Notifications
You must be signed in to change notification settings - Fork 5
/
newRottingOranges.cpp
79 lines (74 loc) · 2.59 KB
/
newRottingOranges.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
// C++ program to rot all oranges when u can move
// in all the four direction from a rotten orange
#include <bits/stdc++.h>
using namespace std;
int orangesRotting(vector<vector<int>> &grid)
{
int m = grid.size();
int n = grid[0].size();
if (grid.empty())
return 0; //this is base case.. if we don't have any orange to rotten then it will take 0 days
int count = 0, days = 0, total = 0;
queue<pair<int, int>> q;
for (int i = 0; i < m; i++)
{
for (int j = 0; j < n; j++)
{
if (grid[i][j] == 2)
{ //this is done to push all the rotten oranges to the queue
q.push({i, j});
}
if (grid[i][j] != 0)
{ //this is helpful when we have to check that all the oranges are rotten or not in future
total++;
}
}
}
//this are the only directions in which our bfs will go.. so i used arrays for x and y coordinate
int dx[4] = {0, 0, 1, -1};
int dy[4] = {1, -1, 0, 0};
while (!q.empty())
{
int k = q.size(); // at one day we can rot this many oranges
count += k;
while (k--)
{
int x = q.front().first;
int y = q.front().second;
q.pop();
for (int i = 0; i < 4; i++)
{ // by using this loop we may go in four possible directions..
int nx = x + dx[i];
int ny = y + dy[i];
//now we have check the conditions for bounds and if there is blank space or already rotten orange then we will simply ignore
if (nx < 0 || nx >= m || ny >= n || ny < 0 || grid[nx][ny] != 1)
continue;
grid[nx][ny] = 2; //after that we will mark the orange as rotten and push it into our queue data structure
q.push({nx, ny});
}
}
if (!q.empty())
days++; //this is used to check how many days are required to rotten all the oranges
}
return total == count ? days : -1; //if the total elements leaving blank space is equal to the elements pushed inside the queue then we can say our all oranges are rottened and we will simply return days otherwise we will return -1..
}
// Driver function
int main()
{
int r, c;
cin >> r >> c;
vector<vector<int>> grid;
for (int i = 0; i < r; i++)
{
vector<int> temp;
for (int j = 0; j < c; j++)
{
int ele;
cin >> ele;
temp.push_back(ele);
}
grid.push_back(temp);
}
cout << orangesRotting(grid) << endl;
return 0;
}