TakahiroNakamori

TakahiroNakamori

中森崇博(ナカモリタカヒロ)

01 /
09
2022
 

Prefix K-th Max

問題

D – Prefix K-th Max
プログラミング初級者から上級者まで楽しめる、競技プログラミングコンテストサイト「AtCoder」。オンラインで毎週開催プログラミングコンテストを開催しています。競技…

記録

解法

コード例

#include <bits/stdc++.h>
using namespace std;
#include <atcoder/all>
using namespace atcoder;
using ll = long long;
using P = pair<int, int>;
#define rep(i, n) for(int i = 0; i < (n); ++i)
// using mint = modint998244353;
// using mint = modint1000000007;
// const int mod = 1000000007;
// const ll INF = 1LL << 62;
// const int INF = 1001001001;

int main() {
  int N, K;
  cin >> N >> K;

  vector<int> P(N);
  rep(i, N) { cin >> P[i]; }

  priority_queue<int, vector<int>, greater<int>> que;
  int current = 0;
  rep(i, N) {
    if(i < K - 1) {
      que.push(P[i]);
      current = que.top();
    } else if(i == K - 1) {
      que.push(P[i]);
      current = que.top();
      cout << current << endl;
    } else {
      if(P[i] < current) {
        cout << current << endl;
      } else {
        que.pop();
        que.push(P[i]);
        current = que.top();
        cout << current << endl;
      }
    }
  }

  return 0;
}