#include using namespace std; #include using namespace atcoder; using ll = long long; using mint = modint1000000007; // {min, cnt_min} using S = array; S op(S x, S y) { if(x[0] < y[0]) return x; if(x[0] > y[0]) return y; return S{x[0], x[1] + y[1]}; } S e() { return S{INT_MAX, 0}; } S mapping(int f, S x) { return S{x[0] + f, x[1]}; } int composition(int f, int g) { return f + g; } int id() { return 0; } int main() { int N, Q; cin >> N >> Q; using query = array; vector qry(Q); vector _seg(N, S{0, 1}); lazy_segtree seg(_seg); for(int i = 0; i < Q; i++) { int t; cin >> t; if(t == 1) { int l, r; cin >> l >> r; l--, r--; seg.apply(l, r, 1); qry[i][0] = t; qry[i][1] = l; qry[i][2] = r; }else if(t == 2) { int q, l, r; cin >> q; q--, l = qry[q][1], r = qry[q][2]; seg.apply(l, r, -1); }else { cout << seg.all_prod()[1] << "\n"; } } }