#include using namespace std; using ll = long long; const int INF = (int)1e9 + 1001010; const ll llINF = (long long)4e18 + 22000020; const string endn = "\n"; template inline auto vector2(size_t i, size_t j, const T &init = T()) {return vector(i, vector(j, init));} const string ELM_SEP = endn, VEC_SEP = endn; template istream& operator >>(istream &i, vector &A) {for(auto &I : A) {i >> I;} return i;} template ostream& operator <<(ostream &o, const vector &A) {int i=A.size(); for(const auto &I : A){o << I << (--i ? ELM_SEP : "");} return o;} template ostream& operator <<(ostream &o, const vector> &A) {int i=A.size(); for(const auto &I : A){o << I << (--i ? VEC_SEP : "");} return o;} template vector& operator ++(vector &A, int n) {for(auto &I : A) {I++;} return A;} template vector& operator --(vector &A, int n) {for(auto &I : A) {I--;} return A;} template bool chmax(T &a, const U &b) {return ((a < b) ? (a = b, true) : false);} template bool chmin(T &a, const U &b) {return ((a > b) ? (a = b, true) : false);} ll floor(ll a, ll b){if (b < 0) a = -a, b = -b; if(a >= 0) return a / b; else return (a + 1) / b - 1;} ll ceil(ll a, ll b){if (b < 0) a = -a, b = -b; if(a > 0) return (a - 1) / b + 1; else return a / b;} ll bit(unsigned long long val, unsigned long long digit){return (val >> digit) & 1;} #ifdef DEBUG #include #define dump(...) cpp_dump(__VA_ARGS__) namespace cp = cpp_dump; struct InitCppDump{ InitCppDump(){ if(!isatty(fileno(stderr))) CPP_DUMP_SET_OPTION(es_style, cpp_dump::es_style_t::no_es); CPP_DUMP_SET_OPTION(log_label_func, cp::log_label::line()); CPP_DUMP_SET_OPTION(max_iteration_count, 30); } } init_cpp_dump; #else #define dump(...) #endif // ================================== ここまでテンプレ ================================== template using max_heap = priority_queue; template using min_heap = priority_queue, greater>; int main(int argc, char *argv[]){ ios::sync_with_stdio(false); cin.tie(nullptr); ll n, q; cin >> n >> q; vector ans; min_heap> great, normal; set great_set; for(int qid = 0; qid < q; qid++){ int op; cin >> op; auto get_out = [&]() -> void { vector> outs; while(great.size() + normal.size() > n){ if(!normal.empty()){ auto [r, s] = normal.top(); normal.pop(); if(great_set.count(s)){ great.emplace(r, s); } else{ outs.emplace_back(r, s); } } else{ auto [r, s] = great.top(); great.pop(); outs.emplace_back(r, s); } } ranges::sort(outs); for(auto [r, s] : outs){ ans.emplace_back(s); } }; if(op == 1){ string s; ll r; cin >> s >> r; normal.emplace(r, s); get_out(); } if(op == 2){ ll x; cin >> x; n -= x; get_out(); } if(op == 3){ string s; ll x; cin >> s >> x; great_set.emplace(s); n += x; } } cout << ans << endl; return 0; }