Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- #include <algorithm>
- #include <cmath>
- #include <iostream>
- #include <map>
- #include <string>
- #include <vector>
- #include <set>
- using namespace std;
- class RouteManager {
- public:
- void AddRoute(int start, int finish) {
- reachable_lists_[start].insert(finish);
- reachable_lists_[finish].insert(start);
- }
- int FindNearestFinish(int start, int finish) const {
- int result = abs(start - finish);
- if (reachable_lists_.count(start) < 1) {
- return result;
- }
- const set<int>& reachable_stations = reachable_lists_.at(start);
- if (!reachable_stations.empty()) {
- const auto it = reachable_stations.lower_bound(finish);
- if (it == reachable_stations.begin()) {
- return min(result, abs(finish - *it));
- }
- const auto prev_it = std::prev(it);
- if (it == reachable_stations.end() || abs(finish - *prev_it) <= abs(finish - *it)) {
- return min(result, abs(finish - *prev_it));
- }
- else {
- return min(result, abs(*it - finish));
- }
- }
- return result;
- }
- private:
- map<int, set<int>> reachable_lists_;
- };
- int main() {
- RouteManager routes;
- int query_count;
- cin >> query_count;
- for (int query_id = 0; query_id < query_count; ++query_id) {
- string query_type;
- cin >> query_type;
- int start, finish;
- cin >> start >> finish;
- if (query_type == "ADD"s) {
- routes.AddRoute(start, finish);
- } else if (query_type == "GO"s) {
- cout << routes.FindNearestFinish(start, finish) << "\n"s;
- }
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement