結果
問題 | No.649 ここでちょっとQK! |
ユーザー | しーぷら |
提出日時 | 2024-05-12 13:23:42 |
言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 211 ms / 3,000 ms |
コード長 | 12,743 bytes |
コンパイル時間 | 6,414 ms |
コンパイル使用メモリ | 352,952 KB |
実行使用メモリ | 16,128 KB |
最終ジャッジ日時 | 2024-12-20 09:06:15 |
合計ジャッジ時間 | 12,593 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 2 ms
6,816 KB |
testcase_01 | AC | 2 ms
6,820 KB |
testcase_02 | AC | 2 ms
6,816 KB |
testcase_03 | AC | 26 ms
6,820 KB |
testcase_04 | AC | 185 ms
15,872 KB |
testcase_05 | AC | 186 ms
16,128 KB |
testcase_06 | AC | 188 ms
16,000 KB |
testcase_07 | AC | 3 ms
6,820 KB |
testcase_08 | AC | 2 ms
6,820 KB |
testcase_09 | AC | 2 ms
6,816 KB |
testcase_10 | AC | 2 ms
6,816 KB |
testcase_11 | AC | 2 ms
6,816 KB |
testcase_12 | AC | 85 ms
8,576 KB |
testcase_13 | AC | 81 ms
8,448 KB |
testcase_14 | AC | 78 ms
8,448 KB |
testcase_15 | AC | 85 ms
8,704 KB |
testcase_16 | AC | 80 ms
9,088 KB |
testcase_17 | AC | 91 ms
9,472 KB |
testcase_18 | AC | 107 ms
9,856 KB |
testcase_19 | AC | 121 ms
10,240 KB |
testcase_20 | AC | 139 ms
10,880 KB |
testcase_21 | AC | 141 ms
11,520 KB |
testcase_22 | AC | 150 ms
11,904 KB |
testcase_23 | AC | 166 ms
12,416 KB |
testcase_24 | AC | 181 ms
12,928 KB |
testcase_25 | AC | 210 ms
13,312 KB |
testcase_26 | AC | 211 ms
13,952 KB |
testcase_27 | AC | 2 ms
6,816 KB |
testcase_28 | AC | 3 ms
6,816 KB |
testcase_29 | AC | 3 ms
6,820 KB |
testcase_30 | AC | 66 ms
8,576 KB |
testcase_31 | AC | 70 ms
8,960 KB |
testcase_32 | AC | 2 ms
6,820 KB |
testcase_33 | AC | 2 ms
6,820 KB |
testcase_34 | AC | 2 ms
6,820 KB |
testcase_35 | AC | 2 ms
6,820 KB |
ソースコード
#include <bits/stdc++.h> #include <ext/pb_ds/assoc_container.hpp> using namespace __gnu_pbds; #pragma GCC target("avx") #pragma GCC optimize("O3") #pragma GCC optimize("unroll-loops") using namespace std; using namespace __gnu_pbds; #ifdef Himesaka #include <noachan.hpp> #define debug(...) debug_print::multi_print(#__VA_ARGS__, __VA_ARGS__) #else #define debug(...) (static_cast<void>(0)) #endif // clang-format off /* #language C++ GCC */ struct Init { Init() { ios::sync_with_stdio(0); cin.tie(0); cout << setprecision(13); } }init; constexpr char nl = '\n'; #define _overload3(_1, _2, _3, name, ...) name #define _rep(i, n) repi(i, 0, n) #define repi(i, a, b) for (lint i = lint(a); i < lint(b); ++i) #define rep(...) _overload3(__VA_ARGS__, repi, _rep, )(__VA_ARGS__) #define all(a) (a).begin(), (a).end() #define rall(x) (x).rbegin(), (x).rend() #define SUM(v) accumulate(all(v), (ll)0) #define MIN(v) *min_element(all(v)) #define MAX(v) *max_element(all(v)) #define pb push_back #define is insert #define fi first #define sc second #define ifnot(x) if(!(x)) #define al(i, v) for (auto &i : v) #define alm(ii,mm) for(auto ii=mm.begin();ii!=mm.end();ii++) #define yes() cout << "Yes" << '\n' #define no() cout << "No" << '\n' #define yn(n) cout << ((n) ? "Yes" : "No") << '\n' #define co() cout << nl; #define len(c) (lint)(c).size() #define inr(l, x, r) (l <= x && x <= r) #define popcount(x) __builtin_popcountll(x) typedef string str;typedef long long ll;typedef long long lint;typedef long double ld;typedef pair<lint,lint>pll;typedef pair<int,int>pii;typedef vector<int> vi;typedef vector<bool> vb;typedef vector<ld> vd;typedef vector<char> vc;typedef vector<ll> vl;typedef vector<str> vs;typedef vector<vector<int>> vvi;typedef vector<vector<ll>> vvl;typedef vector<vector<char>> vvc;typedef vector<vector<bool>> vvb;typedef vector<pll> vpl;template<class T>void snx(T &a){cin>>a;}void inz() {}template <class Head, class... Tail>void inz(Head &head, Tail &...tail){snx(head);inz(tail...);} template <typename T> using tree_set = tree<T, null_type, less<T>, rb_tree_tag, tree_order_statistics_node_update>; #define scan(x) al(i, x) cin >> i #define int_(...) int __VA_ARGS__;inz(__VA_ARGS__) #define lint_(...) lint __VA_ARGS__;inz(__VA_ARGS__) #define ld_(...) ld __VA_ARGS__;inz(__VA_ARGS__) #define str_(...) string __VA_ARGS__;inz(__VA_ARGS__) #define char_(...) char __VA_ARGS__;inz(__VA_ARGS__) #define vi_(ne,sz) vi ne(sz);scan(ne); #define vl_(ne,sz) vl ne(sz);scan(ne); #define vb_(ne,sz) vb ne(sz);scan(ne); #define vd_(ne,sz) vd ne(sz);scan(ne); #define vc_(ne,sz) vc ne(sz);scan(ne); #define vs_(ne,sz) vs ne(sz);scan(ne); #define snn(h,w,a) rep(i,h)rep(j,w) cin >> a[i][j]; #define vvi_(ne,h,w) vvi ne(h,vi(w,0));snn(h,w,ne) #define vvl_(ne,h,w) vvl ne(h,vl(w,0));snn(h,w,ne) #define vvc_(ne,h,w) vvc ne(h,vc(w,0));snn(h,w,ne) #define vvb_(ne,h,w) vvb ne(h,vb(w,0));snn(h,w,ne) #define vpl_(ne,m) vpl ne(m); rep(i,m)cin>>ne[i].fi>>ne[i].sc; ostream &operator<<(ostream &os, const vpl &v) {for (auto &[e1, e2] : v){os << e1 << ' ' << e2 << endl;}return os;} template <class T> ostream &operator<<(ostream &os, const vector<T> &v){for (auto &e : v)os << e << ' ';return os;} template <class T> ostream &operator<<(ostream &os, const set<T> &v){for (auto &e : v)os << e << ' ';return os;} template <class T> ostream &operator<<(ostream &os, const multiset<T> &v){for (auto &e : v)os << e << ' ';return os;} template <class T> vector<T> &operator++(vector<T> &v) {al(e,v) e++;return v;} template <class T> vector<T> operator++(vector<T> &v, signed) {auto res = v;al(e,v) e++;return res;} template <class T> vector<T> &operator--(vector<T> &v) {al(e,v) e--;return v;} template <class T> vector<T> operator--(vector<T> &v, signed) {auto res = v;al(e,v) e--;return res;} vector<pll> &operator--(vector<pll> &v) {al(e,v) e.fi--,e.sc--;return v;} vector<pll> operator--(vector<pll> &v, signed) {auto res = v;al(e,v)e.fi--,e.sc--;return res;} template<> struct std::vector<bool>: std::basic_string<bool> {using std::basic_string<bool>::basic_string, std::basic_string<bool>::operator =;explicit vector(size_t n): vector(n, false) {}}; template <class T> set<T> operator|(set<T> a, set<T> b){set<T> ret;set_union(all(a), all(b), inserter(ret, ret.begin()));return ret;} template <class T> multiset<T> operator|(multiset<T> a, multiset<T> b){multiset<T> ret;set_union(all(a), all(b), inserter(ret, ret.begin()));return ret;} template <class T> set<T> operator&(set<T> a, set<T> b){set<T> ret;set_intersection(all(a), all(b), inserter(ret, ret.begin()));return ret;} template <class T> multiset<T> operator&(multiset<T> a, multiset<T> b){multiset<T> ret;set_intersection(all(a), all(b), inserter(ret, ret.begin()));return ret;} template <class T> set<T> operator-(set<T> a, set<T> b){set<T> ret;set_symmetric_difference(all(a), all(b), inserter(ret, ret.begin()));return ret;} template <class T> multiset<T> operator-(multiset<T> a, multiset<T> b){multiset<T> ret;set_symmetric_difference(all(a), all(b), inserter(ret, ret.begin()));return ret;} ostream &operator<<(ostream &os, const vvc &v) {for (auto &e : v){for (auto &c : e)os << c;os << endl;}return os;} ostream &operator<<(ostream &os, const vvl &v) {for (auto &e : v){for (auto &c : e)os << c << ' ';os << endl;}return os;} template <class... T> void input(T &...a){(cin >> ... >> a);} void out(){cout << '\n';}template <class T, class... Ts>void out(const T &a, const Ts &...b){cout << a; (cout << ... << (cout << ' ', b));cout << '\n';} void print(){cout << '\n';}template <class T, class... Ts>void print(const T &a, const Ts &...b){cout << a; (cout << ... << (cout << ' ', b));cout << '\n';} void exit_no(void){cout<<"No"<<nl; exit(0);};void exit_yes(void){cout<<"Yes"<<nl; exit(0);}; //template <class T> void exit_(T x){cout<<x<<nl; exit(0);}; void exit_(){cout << '\n';exit(0);} template<class T, class... Ts> void exit_(const T& a, const Ts&... b){cout << a;(cout << ... << (cout << ' ', b));cout << '\n';exit(0);} template <class T> bool chmin(T &a, const T &b) { return a > b ? a = b, true : false; } template <class T> bool chmax(T &a, const T &b) { return a < b ? a = b, true : false; } template <class T> void sort(T &v) {sort(all(v));} template <class T> void rsort(T &v) {sort(rall(v));} template <class T> void reverse(T &v) {reverse(all(v));} template <class T> vector<T> ret_ex(vector<T> v){T n = len(v);vector<T> e(n + 1, 0);rep(i, 1, n + 1) e[i] = e[i - 1] + v[i - 1];return e;} template<class T> map<T,lint> count_v(vector<T> v){map<T,lint>res;al(x,v)res[x]++;return res;} map<char,lint>count_s(str s) {map<char,lint>res;al(x,s)res[x]++;return res;} template<class T,class U> bool is_out(T y,T x,U h,U w){return (y<0||y>=h||x<0||x>=w);} const string ABC = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; const string abc = "abcdefghijklmnopqrstuvwxyz"; const lint dx[8] = {1,0,-1,0,1,-1,-1,1},dy[8]={0,1,0,-1,1,1,-1,-1}; const int inf = INT_MAX/2; const lint infl = 1LL<<60; const ld PI = acos(-1.0); template <class T> vector<vector<T>> r_rot(vector<vector<T>> g) {lint h = g.size(), w = g[0].size();vector<vector<T>> res(h, vector<T>(w));rep(i, h) rep(j, w) res[j][w - 1 - i] = g[i][j];return res;} template <class T> vector<vector<T>> l_rot(vector<vector<T>> g) {lint h = g.size(), w = g[0].size();vector<vector<T>> res(h, vector<T>(w));rep(i, h) rep(j, w) res[w - 1 - j][i] = g[i][j];return res;} set<pll> normalize_grid(vvc g){set<pll> se;rep(i, g.size()) rep(j, len(g[i])){if (g[i][j] == '#')se.is({i, j});}lint miy{infl}, mix{infl};al(x, se){chmin(miy, x.fi);chmin(mix, x.sc);}set<pll> ans;al(x, se)ans.is({x.fi - miy, x.sc - mix});return ans;} multiset<pll> m_normalize_grid(vvc g){multiset<pll> se;rep(i, g.size()) rep(j, len(g[i])){if (g[i][j] == '#')se.is({i, j});}lint miy{infl}, mix{infl};al(x, se){chmin(miy, x.fi);chmin(mix, x.sc);}multiset<pll> ans;al(x, se)ans.is({x.fi - miy, x.sc - mix});return ans;} set<pll> normalize_set(set<pll> se){lint miy{infl}, mix{infl};al(x, se){chmin(miy, x.fi);chmin(mix, x.sc);}set<pll> ans;al(x, se)ans.is({x.fi - miy, x.sc - mix});return ans;} multiset<pll> m_normalize_set(multiset<pll> se){lint miy{infl}, mix{infl};al(x, se){chmin(miy, x.fi);chmin(mix, x.sc);}multiset<pll> ans;al(x, se)ans.is({x.fi - miy, x.sc - mix});return ans;} bool NE(ld a, ld b){return abs(a - b) < DBL_EPSILON;} template<class T> T pow_mod(T A, T N, T M) {T res = 1 % M;A %= M;while (N) {if (N & 1) res = (res * A) % M;A = (A * A) % M;N >>= 1;}return res;} bool is_prime(ll N) {if (N <= 1)return false;if (N == 2 || N == 3)return true;if (N % 2 == 0)return false;vl A = {2, 325, 9375, 28178, 450775,9780504, 1795265022};ll s = 0, d = N - 1;while (d % 2 == 0){++s;d >>= 1;}for (auto a : A){if (a % N == 0)return true;ll t, x = pow_mod<__int128_t>(a, d, N);if (x != 1){for (t = 0; t < s; ++t){if (x == N - 1)break;x = __int128_t(x) * x % N;}if (t == s)return false;}}return true;} ll pollard(ll N) {if (N % 2 == 0)return 2;if (is_prime(N))return N;auto f = [&](ll x) -> ll {return (__int128_t(x) * x + 1) % N;};ll step = 0;while (true){++step;ll x = step, y = f(x);while (true){ll p = gcd(y - x + N, N);if (p == 0 || p == N)break;if (p != 1)return p;x = f(x);y = f(f(y));}}} vl prime_factorize(ll N){if (N == 1)return {};ll p = pollard(N);if (p == N)return {p};vl left = prime_factorize(p);vl right = prime_factorize(N / p);left.is(left.end(), right.begin(), right.end());sort(all(left));return left;} vpl prime_fact(lint n) {vl pr = prime_factorize(n);vpl ans{};rep(i, len(pr)){lint cnt{1}, num = pr[i];while (i + 1 < len(pr) && pr[i + 1] == num)cnt++, i++;ans.pb({num, cnt});}return ans;} template<class T> T d_pow(T x, T n) {T ret = 1;while (n > 0){if (n & 1)ret *= x;x *= x;n >>= 1;}return ret;} template<class T> T digitnum(T x, T b = 10){T ret = 0; for(; x; x /= b) ret++; return ret;} template<class T> T digitsum(T x, T b = 10){T ret = 0; for(; x; x /= b) ret += x % b; return ret;} template <class T, class U> str to_baseB(T x, U b) {str r{};while (x){lint n = x % b;r = (char)((n <= 9) ? ('0' + n) : ('A' + n - 10)) + r;x /= b;}return r;} lint to_base10(str x, lint b = 10) {lint r{}, base = 1;for (lint i = len(x) - 1; i >= 0; --i){lint n = ('0' <= x[i] && x[i] <= '9') ? (x[i] - '0') : (x[i] - 'A' + 10);r += base * n;base *= b;}return r;} template<class T> T nPr(T n, T r) {T i, result = 1;rep(i, r) { result *= (T)(n - i); }return result;} template<class T> T nCr(T n, T r){T i,result = 1;rep(i, min(r, n - r)){result *= (T)(n - i);result /= (T)(i + 1);}return result;} template <class T> vector<T> div(T n){vector<T> ret;for (T i = 1; i * i <= n; i++)if (!(n % i)){ ret.pb(i);if (i * i != n) ret.pb(n / i);}sort(all(ret)); return ret;} ll arith(ll x) { return x * (x + 1) / 2; } ll arith2(ll a, ll d, ll n){return n * (2 * a + (n - 1) * d) / 2; } vl sieve(lint n) {vl res;vector<int> mem(n, 0);for (int i = 2; i < n; i++){if (mem[i]){continue;}res.push_back(i);for (int j = i; j < n; j += i){mem[j] = 1;}}return res;} lint ret_dist(lint y1,lint x1,lint y2,lint x2){return powl(y2 - y1,2) + powl(x2 - x1,2);} lint mgr(lint ok, lint ng, auto is_ok) {while (abs(ok - ng) > 1){lint mid = (ok + ng) / 2;is_ok(mid) ? ok = mid : ng = mid;};return ok;} ld mgr_double(ld ok, ld ng, auto is_ok) {rep(_, 60){ld mid = (ok + ng) / 2;is_ok(mid) ? ok = mid : ng = mid;}return ok;} // clang-format on template <typename T> class Comp { vector<T> vals; vector<int> comp; public: Comp(const vector<T> &data) : vals(data), comp(data.size()) { sort(vals.begin(), vals.end()); vals.erase(unique(vals.begin(), vals.end()), vals.end()); for (int i = 0; i < comp.size(); i++) comp[i] = lower_bound(vals.begin(), vals.end(), data[i]) - vals.begin(); } int get_index(T value) { auto lb = lower_bound(vals.begin(), vals.end(), value); assert(lb != vals.end() && *lb == value); return (int)(lb - vals.begin()); } T get_value(size_t index) { return vals.at(index); } int operator[](size_t index) const { return comp.at(index); } vector<int> get_compressed_vector() const { return comp; } int size() const { return vals.size(); } }; #include <ext/pb_ds/assoc_container.hpp> using namespace __gnu_pbds; template <typename T> using tree_set = tree<T, null_type, less<T>, rb_tree_tag, tree_order_statistics_node_update>; int main() { tree_set<pll> se; lint_(q, k); lint cnt{}; for (; q--;) { lint_(t); if (t == 1) { lint_(x); se.is({x, cnt++}); } if (t == 2) { if (se.size() < k) out(-1); else { auto it = se.find_by_order(k - 1); out(it->fi); se.erase(it); } } } }