There are $n$ persons who initially don’t know each other. On each morning, two of them, who were not friends before, become friends.
We want to plan a trip for every evening of $m$ days. On each trip, you have to select a group of people that will go on the trip. For every person, one of the following should hold:
- Either this person does not go on the trip,
- Or at least $k$ of his friends also go on the trip.
Note that the friendship is not transitive. That is, if $a$ and $b$ are friends and $b$ and $c$ are friends, it does not necessarily imply that $a$ and $c$ are friends.
For each day, find the maximum number of people that can go on the trip on that day.
Input
The first line contains three integers $n$, $m$, and $k$ ($2 \leq n \leq 2 \cdot 10^5, 1 \leq m \leq 2 \cdot 10^5$, $1 \le k < n$) — the number of people, the number of days and the number of friends each person on the trip should have in the group.
The $i$-th ($1 \leq i \leq m$) of the next $m$ lines contains two integers $x$ and $y$ ($1\leq x, y\leq n$, $x\ne y$), meaning that persons $x$ and $y$ become friends on the morning of day $i$. It is guaranteed that $x$ and $y$ were not friends before.
Output
Print exactly $m$ lines, where the $i$-th of them ($1\leq i\leq m$) contains the maximum number of people that can go on the trip on the evening of the day $i$.
Examples
input
4 4 2
2 3
1 2
1 3
1 4
output
0
0
3
3
input
5 8 2
2 1
4 2
5 4
5 2
4 3
5 1
4 1
3 2
output
0
0
0
3
3
4
4
5
input
5 7 2
1 5
3 2
2 5
3 4
1 2
5 3
1 3
output
0
0
0
0
3
4
4
Note
In the first example,
- $1,2,3$ can go on day $3$ and $4$.
In the second example,
- $2,4,5$ can go on day $4$ and $5$.
- $1,2,4,5$ can go on day $6$ and $7$.
- $1,2,3,4,5$ can go on day $8$.
In the third example,
- $1,2,5$ can go on day $5$.
- $1,2,3,5$ can go on day $6$ and $7$.
Solution:
#include <bits/stdc++.h> using namespace std; int main() { ios::sync_with_stdio(false); cin.tie(0); int n, m, k; cin >> n >> m >> k; vector<vector<pair<int,int>>> g(n); vector<int> from(m), to(m); for (int i = 0; i < m; i++) { cin >> from[i] >> to[i]; from[i]--; to[i]--; g[from[i]].emplace_back(to[i], i); g[to[i]].emplace_back(from[i], i); } vector<int> alive(m, 1); vector<int> deg(n); vector<int> que; for (int i = 0; i < n; i++) { deg[i] = (int) g[i].size(); if (deg[i] < k) { que.push_back(i); } } int b = 0; vector<int> res(m); for (int step = m - 1; step >= 0; step--) { while (b < (int) que.size()) { int i = que[b]; for (auto &p : g[i]) { if (!alive[p.second]) { continue; } alive[p.second] = 0; if (deg[p.first] == k) { que.push_back(p.first); } deg[p.first]--; deg[i]--; } b++; } res[step] = n - (int) que.size(); if (alive[step]) { if (deg[from[step]] == k) { que.push_back(from[step]); } if (deg[to[step]] == k) { que.push_back(to[step]); } deg[from[step]]--; deg[to[step]]--; alive[step] = 0; } } for (int i = 0; i < m; i++) { cout << res[i] << '\n'; } return 0; }