Minimum number of stops from given path in C++

C++Server Side ProgrammingProgramming

Problem statement

  • There are many points in two-dimensional space which need to be visited in a specific sequence.
  • Path from one point to other is always chosen as shortest path and path segments are always aligned with grid lines.
  • We are given the path which is chosen for visiting the points. We need to tell the minimum number of points that must be needed to generate given paths.

Algorithm

1. We can solve this problem by observing the pattern of movement when visiting the stop
2. If we want to take the shortest path from one point to another point, then we will move in either one or max two directions

Example

 Live Demo

#include <bits/stdc++.h>
using namespace std;
int getMinStops(string path) {
   int n = path.length();
   map<char, int> directionMap;
   int stops = 1;
   for (int i = 0; i < n; ++i) {
      char direction = path[i];
      directionMap[direction] = 1;
      if ((directionMap['L'] && directionMap['R']) ||
      (directionMap['U'] && directionMap['D'])) {
         directionMap.clear();
         ++stops;
         directionMap[direction] = 1;
      }
   }
   return stops + 1;
}
int main() {
   string path = "LLUUULLDD";
   cout << "Minimum stops = " << getMinStops(path) << endl;
   return 0;
}

When you compile and execute above program. It generates following output

Output

Minimum stops = 3
raja
Published on 23-Dec-2019 06:20:19
Advertisements