Description
data:image/s3,"s3://crabby-images/aeb1e/aeb1ebe2499f74365febe93eb27592aa262e7216" alt=""
Submission
class Solution { public: bool isPathCrossing(string path) { map<char, pair<int, int>> dirs{{'N', {0, 1}}, {'S', {0, -1}}, {'W', {-1, 0}}, {'E', {1, 0}}}; set<pair<int, int>> visited; pair<int, int> cur = {0, 0}; visited.insert(cur); for(auto c: path) { cur.first += dirs[c].first; cur.second += dirs[c].second; if(visited.find(cur) != visited.end()) return true; visited.insert(cur); } return false; } };
data:image/s3,"s3://crabby-images/ea1ef/ea1efd9a446fed46feab9a4fee79a8a29a67a92f" alt=""