#include #include #include #include #include #include #include #include #include #include using namespace std; #define int long long int MOD = 1000000007; struct UnionFind { vector data; vector mn; UnionFind(int size) { data.resize(size, -1); mn.resize(size, -1); for (int i = 0; i < size; i++) { mn[i] = i; } } bool unionSet(int x, int y) { x = root(x); y = root(y); if (x != y) { if (x < y) swap(x, y); data[x] += data[y]; data[y] = x; mn[x] = min(mn[x], mn[y]); } return x != y; } bool findSet(int x, int y) { return root(x) == root(y); } int root(int x) { return data[x] < 0 ? x : data[x] = root(data[x]); } int size(int x) { return -data[root(x)]; } }; template struct fenwick_tree { vector x; fenwick_tree(int n) : x(n, 0) { } T sum(int i, int j) { if (i == 0) { T S = 0; for (j; j >= 0; j = (j & (j + 1)) - 1) S += x[j]; return S; } else return sum(0, j) - sum(0, i - 1); } void add(int k, T a) { for (; k < x.size(); k |= k + 1) x[k] += a; } }; signed main() { cin.tie(0); ios::sync_with_stdio(false); int D, Q; cin >> D >> Q; vector A(Q); vector B(Q); map mp; vector inv; for (int i = 0; i < Q; i++) { cin >> A[i] >> B[i]; mp[A[i]] = 0; mp[A[i] + 1] = 0; mp[A[i] - 1] = 0; mp[B[i]] = 0; mp[B[i] + 1] = 0; mp[B[i] - 1] = 0; } for (auto m : mp) { inv.push_back(m.first); } for (int i = 0; i < inv.size(); i++) { mp[inv[i]] = i; } fenwick_tree ft((int)inv.size() + 1); UnionFind uf((int)inv.size()); int res = 1; for (int i = 0; i < Q; i++) { A[i] = mp[A[i]]; B[i] = mp[B[i]]; ft.add(A[i], 1); ft.add(B[i] + 1, -1); if (A[i] > 0) { if (ft.sum(0, A[i] - 1) > 0) { uf.unionSet(A[i] - 1, A[i]); } } int x = A[i]; //cerr << "st = " << A[i] << endl; while (true) { if (x + 1 < (int)inv.size() && ft.sum(0, x + 1) > 0) { uf.unionSet(x, x + 1); } else { break; } x = uf.root(x); //cerr << "x=" << x << endl; } res = max(res, inv[x] - inv[uf.mn[x]] + 1); //cerr << x << " " << uf.mn[x] << endl; cout << res << endl; } }