結果
| 問題 | No.649 ここでちょっとQK! |
| コンテスト | |
| ユーザー |
noppo_puyo
|
| 提出日時 | 2018-10-19 10:16:14 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
RE
|
| 実行時間 | - |
| コード長 | 1,017 bytes |
| コンパイル時間 | 1,039 ms |
| コンパイル使用メモリ | 96,084 KB |
| 実行使用メモリ | 19,620 KB |
| 最終ジャッジ日時 | 2024-11-15 22:32:19 |
| 合計ジャッジ時間 | 42,375 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 19 RE * 4 TLE * 9 |
ソースコード
#include<iostream>
#include<vector>
#include<string>
#include<array>
#include<cmath>
#include<algorithm>
#include<map>
#include<set>
#include<queue>
#include<numeric>
#include<iomanip>
#include<utility>
#include<cstdlib>
#include<typeinfo>
typedef long long int lint;
using namespace std;
#define INF 1000000000000000005
int main()
{
lint q,k;
std::cin >> q >> k;
multiset<lint> query;
lint index = 0;
for(lint i = 0; i < q; i++){
lint temp = 0;
std::cin >> temp;
if(temp == 1){
lint v = 0;
std::cin >> v;
query.insert(v);
index++;
} else {
if(index >= k){
auto itr = query.begin();
if(k <= q/2){
std::advance(itr,k - 1);
} else {
itr = query.end();
std::advance(itr,index - k);
}
std::cout << *itr << std::endl;
query.erase(itr);
index--;
} else {
std::cout << -1 << std::endl;
}
}
}
return 0;
}
noppo_puyo