#include using namespace std; vector> g; int n, k, ans; void dfs(int v, int pv) { k--; if (0 < k) ans++; for (auto nv : g[v]) { if (nv == pv) continue; dfs(nv, v); } } int main() { cin >> n >> k; g.assign(n, vector()); for (int i = 0; i < n - 1; i++) { int a, b; cin >> a >> b; a--, b--; g[a].emplace_back(b); g[b].emplace_back(a); } dfs(0, -1); if (k <= 0) { cout << ans << endl; } else { cout << -1 << endl; } return 0; }