Submission #1149022

#TimeUsernameProblemLanguageResultExecution timeMemory
1149022duckindogMousetrap (CEOI17_mousetrap)C++17
100 / 100
445 ms189380 KiB
#include <bits/stdc++.h>

using namespace std;

const int N = 1'000'000 + 10;
int n, t, m;
vector<int> ad[N];

vector<int> path;

int f[N];
bool inPath[N];
void dfs(int u, int p = -1) { 
  inPath[u] = (u == t);
  for (const auto& v : ad[u]) { 
    if (v == p) continue;
    dfs(v, u);
    inPath[u] |= inPath[v];
  }
  if (inPath[u]) path.push_back(u);

  vector<int> best{0, 0};
  for (const auto& v : ad[u]) { 
    if (v == p || inPath[v]) continue;
    best.push_back(f[v]);
  }
  sort(best.begin(), best.end(), greater<>());
  f[u] = best.size() + best[1] - 2;
}

int32_t main() { 
  cin.tie(0)->sync_with_stdio(0);

  cin >> n >> t >> m;
  for (int i = 1; i < n; ++i) { 
    int u, v; cin >> u >> v;
    ad[u].push_back(v);
    ad[v].push_back(u);
  }

  vector<pair<int, int>> value;
  { // build value
    dfs(m);
    reverse(path.begin(), path.end());
    path.pop_back();
    
    int it = 0;
    for (const auto& u : path) {
      it += 1;

      sort(ad[u].begin(), ad[u].end(), [&](const auto& a, const auto& b) { 
        return f[a] > f[b];
      });

      for (const auto& v : ad[u]) { 
        if (!inPath[v]) value.push_back({f[v], it});
      }
    }

    for (int i = 0; i < (int)value.size(); ++i)
      value[i].first += value.size() - i;
  }

  auto chk = [&](int mid) { 
    int it = 0;
    for (const auto& [w, num] : value) { 
      if (it + w > mid) { 
        if (it >= num) return false;
        it += 1;
      }
    }
    return it <= mid;
  };

  int l = 0, r = 2 * n, answer = 0;
  while (l <= r) { 
    int mid = (l + r) >> 1;
    if (chk(mid)) r = (answer = mid) - 1;
    else l = mid + 1;
  }

  cout << answer << "\n";
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...