Given a binary N x N matrix, we need to find the total number of matrix positions from which there is an endless path. Any position (i, j) is said to have an endless path if and only if all of the next positions in its row(i) and its column(j) should have value 1. If any position next to (i,j) either in row(i) or in column(j) will have 0 then position (i,j) doesn’t have any endless path.
Input : 0 1 0 1 1 1 0 1 1 Output : 4 Endless points are (1, 1), (1, 2), (2, 1) and (2, 2). For all other points path to some corner is blocked at some point. Input : 0 1 1 1 1 0 0 1 0 Output : 1 Endless point is (0, 2).
Naive Approach :
We traverse all positions, for every position, we check that does this position has endless path or not. If yes then count it otherwise ignore it. But as usual its time complexity seems to be high.
Time complexity : O(n3)
Also, we can say that any position (i,j) will have an endless row if (i,j+1) will have an endless row and value of (i,j) is 1.
Similarly, we can say that any position (i,j) will have an endless column if (i+1,j) will have an endless column and value of (i,j) is 1.
So we should maintain two matrices one for row and one for column. Always start from right most position for row and bottom most position for column and only check for next position whether it has endless path or not.
And Finally, if any position will have an endless path in both row and column matrix then that position is said to have an endless path.
This article is contributed by Shivam Pradhan (anuj_charm). If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to email@example.com. See your article appearing on the GeeksforGeeks main page and help other Geeks.
Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above.
- Find n-th element from Stern's Diatomic Series
- Find maximum possible stolen value from houses
- Minimum steps to minimize n as per given condition
- Subset with sum divisible by m
- Maximum sum of a path in a Right Number Triangle
- Perfect Sum Problem (Print all subsets with given sum)
- Program for Sudoku Generator
- Count ways to increase LCS length of two strings by one
- Sum of all substrings of a string representing a number | Set 1
- Gold Mine Problem
- Maximum path sum that starting with any cell of 0-th row and ending with any cell of (N-1)-th row
- Size of array after repeated deletion of LIS
- Friends Pairing Problem
- Subset Sum Problem | DP-25
- 0-1 Knapsack Problem | DP-10