結果
問題 |
No.2210 equence Squence Seuence
|
ユーザー |
![]() |
提出日時 | 2024-07-07 12:00:47 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 98 ms / 2,000 ms |
コード長 | 1,101 bytes |
コンパイル時間 | 4,399 ms |
コンパイル使用メモリ | 254,720 KB |
最終ジャッジ日時 | 2025-02-22 02:30:31 |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 25 |
ソースコード
#include <bits/stdc++.h> #include <atcoder/all> using namespace std; using namespace atcoder; #define rep(i, n) for(int i=0;i<(n);++i) #define rep1(i, n) for(int i=1;i<=(n);i++) #define ll long long using mint = modint998244353; using P = pair<ll,ll>; using lb = long double; using T = tuple<ll, ll, ll>; #ifdef LOCAL # include <debug_print.hpp> # define dbg(...) debug_print::multi_print(#__VA_ARGS__, __VA_ARGS__) #else # define dbg(...) (static_cast<void>(0)) #endif int main() { int n, k; cin >> n >> k; vector<int> a(n); rep(i,n) cin >> a[i]; deque<int> q; q.push_back(n-1); dsu uf(n); for(int i=n-1;i>=1;i--){ if(a[i-1]>a[i]) { q.push_front(i-1); } else if(a[i-1]<a[i]) { q.push_back(i-1); } else{ uf.merge(i,i-1); } } vector<int> idx; for(int v : q) { rep(j,uf.size(v)) { idx.push_back(v); } } int num = idx[k-1]; rep(i,n) { if(i==num) continue; cout << a[i] << " "; } cout << endl; return 0; }