結果
問題 | No.1095 Smallest Kadomatsu Subsequence |
ユーザー |
![]() |
提出日時 | 2020-06-26 22:24:56 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 274 ms / 2,000 ms |
コード長 | 1,932 bytes |
コンパイル時間 | 1,831 ms |
コンパイル使用メモリ | 178,744 KB |
実行使用メモリ | 8,936 KB |
最終ジャッジ日時 | 2024-07-04 22:07:35 |
合計ジャッジ時間 | 5,890 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 30 |
ソースコード
#include <bits/stdc++.h>using namespace std;#define REP(i,a,n) for(int i=(a); i<(int)(n); i++)#define rep(i,n) REP(i,0,n)#define FOR(it,c) for(__typeof((c).begin()) it=(c).begin(); it!=(c).end(); ++it)#define ALLOF(c) (c).begin(), (c).end()typedef long long ll;typedef unsigned long long ull;static const int INF = 999999999;class RMQ {int N;std::vector<int> dat;public:RMQ() {}void init(int n_) {N = 1;while (N < n_) N *= 2;for (int i = 0; i < 2 * N - 1; i++)dat.push_back(INF);}int query(int a, int b) { return _query(a, b, 0, 0, N); }int _query(int a, int b, int k, int l, int r) {if (r <= a || b <= l) return INF;if (a <= l && r <= b) return dat[k];else {int vl = _query(a, b, k * 2 + 1, l, (l + r) / 2);int vr = _query(a, b, k * 2 + 2, (l + r) / 2, r);if (vl < vr) return vl;else return vr;}}void update(int i, int x) {i += N - 1;dat[i] = x;while (i > 0) {i = (i - 1) / 2;if (dat[i * 2 + 1] < dat[i * 2 + 2]) {dat[i] = dat[i * 2 + 1];} else {dat[i] = dat[i * 2 + 2];}}}};int main(){int N;cin >> N;vector<pair<int,int>> v;rep(i,N){int a;cin >> a;v.emplace_back(a,i);}sort(ALLOF(v));int ret = INF;{RMQ rmq;rmq.init(N+5);rep(i,v.size()){int x = v[i].first;int idx = v[i].second;int lhs = rmq.query(0,idx);int rhs = rmq.query(idx+1, N);ret = min(ret, lhs + x + rhs);rmq.update(idx, x);}}{RMQ rmq;rmq.init(N+5);for(int i=v.size()-1; i>=0; i--){int x = v[i].first;int idx = v[i].second;int lhs = rmq.query(0,idx);int rhs = rmq.query(idx+1, N);ret = min(ret, lhs + x + rhs);rmq.update(idx, x);}}if(ret == INF) cout << -1 << endl;else cout << ret << endl;return 0;}