https://github.com/emahtab/best-meeting-point
Best Meeting Point
https://github.com/emahtab/best-meeting-point
leetcode median
Last synced: 7 months ago
JSON representation
Best Meeting Point
- Host: GitHub
- URL: https://github.com/emahtab/best-meeting-point
- Owner: eMahtab
- Created: 2021-10-10T04:03:52.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2021-10-13T03:56:53.000Z (about 4 years ago)
- Last Synced: 2025-02-02T03:26:15.919Z (9 months ago)
- Topics: leetcode, median
- Homepage:
- Size: 40 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Best Meeting Point
Given an m x n binary grid grid where each 1 marks the home of one friend, return the minimal total travel distance.The total travel distance is the sum of the distances between the houses of the friends and the meeting point.
The distance is calculated using Manhattan Distance, where distance(p1, p2) = |p2.x - p1.x| + |p2.y - p1.y|.

```
Constraints:1. m == grid.length
2. n == grid[i].length
3. 1 <= m, n <= 200
4. grid[i][j] is either 0 or 1.
5. There will be at least two friends in the grid.
```## 💥💥💥 : Note that, meeting point can be either a house(1 cell) or 0 cell.
# Implementation 1 : Naive : Time Limit Exceeded
Find out the distance from each cell of the grid and return the minimum distance.```java
class Solution {
public int minTotalDistance(int[][] grid) {
if(grid == null || grid.length == 0)
return 0;
int rows = grid.length;
int cols = grid[0].length;
List houses = new ArrayList<>();
for(int i = 0; i < rows; i++) {
for(int j = 0; j < cols; j++) {
if(grid[i][j] == 1) {
houses.add(new int[]{i,j});
}
}
}
int minDistance = Integer.MAX_VALUE;
for(int i = 0; i < rows; i++) {
for(int j= 0; j < cols; j++) {
int distance = getDistanceFromHouses(grid, i, j, houses);
minDistance = Math.min(minDistance, distance);
}
}
return minDistance;
}
public int getDistanceFromHouses(int[][] grid, int row, int col, List houses) {
int totalDistance = 0;
for(int[] house : houses) {
int distance = Math.abs(row - house[0]) + Math.abs(col - house[1]);
totalDistance += distance;
}
return totalDistance;
}
}
```# Implementation 2 : Calculate distance from Median
To find the median cell, we need to arrange the coordinates of the houses in ascending order for both x and y direction.
```java
class Solution {
public int minTotalDistance(int[][] grid) {
if(grid == null || grid.length == 0)
return 0;
int rows = grid.length;
int cols = grid[0].length;
List x = new ArrayList<>();
List y = new ArrayList<>();
// collect x coordinates of houses in ascending order
for(int i = 0; i < rows; i++) {
for(int j = 0; j < cols; j++) {
if(grid[i][j] == 1)
x.add(i);
}
}
// collect y coordinates of houses in ascending order
for(int j = 0; j < cols; j++) {
for(int i = 0; i < rows; i++) {
if(grid[i][j] == 1)
y.add(j);
}
}
int xc = x.get(x.size() / 2);
int yc = y.get(y.size() / 2);
// now calculate the distance from Median (xc,yc)
int minDistance = 0;
for(int i = 0; i < rows; i++) {
for(int j = 0; j < cols; j++) {
if(grid[i][j] == 1) {
minDistance += Math.abs(i - xc) + Math.abs(j - yc);
}
}
}
return minDistance;
}
}
```### Complexity analysis
```
Time complexity : O(mn), where m is number of rows and n is number of columns.Space complexity : O(mn), where m is number of rows and n is number of columns.
```