QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#418641 | #8718. 保区间最小值一次回归问题 | wsyear | WA | 817ms | 124176kb | C++17 | 3.0kb | 2024-05-23 14:57:33 | 2024-05-23 14:57:33 |
Judging History
answer
#include <bits/stdc++.h>
#define rep(i, j, k) for (int i = (j); i <= (k); ++i)
#define per(i, j, k) for (int i = (j); i >= (k); --i)
#define SZ(v) int((v).size())
#define ALL(v) (v).begin(),(v).end()
#define fi first
#define se second
using ll = long long;
using pii = std::pair<int, int>;
using pll = std::pair<ll, ll>;
template<class T>inline void chkmn(T &x, T y) { if (y < x) x = y; }
template<class T>inline void chkmx(T &x, T y) { if (y > x) x = y; }
using namespace std;
const int maxn = 500010;
const int inf = 2e9;
int n, m, tot, a[maxn], mx[maxn], st[maxn][20], c[maxn], tlim[maxn], val[maxn];
ll dp[maxn];
vector<int> mvec[maxn], pos[maxn];
vector<pii> vec[maxn];
tuple<int, int, int> lim[maxn];
multiset<int> S;
int que(int l, int r) {
int k = __lg(r - l + 1);
return min(st[l][k], st[r - (1 << k) + 1][k]);
}
void work() {
cin >> n >> m;
rep (i, 1, n) cin >> a[i];
rep (i, 1, n) mvec[i].clear();
rep (i, 1, m) {
int l, r, v;
cin >> l >> r >> v, c[i] = v;
mvec[l].emplace_back(v);
mvec[r + 1].emplace_back(-v);
lim[i] = make_tuple(l, r, v);
}
S.clear();
rep (i, 1, n) {
for (int x : mvec[i]) {
if (x > 0) S.emplace(x);
else S.erase(S.find(-x));
}
if (S.empty()) mx[i] = st[i][0] = inf;
else mx[i] = st[i][0] = *prev(S.end());
}
rep (j, 1, 19) rep (i, 1, n - (1 << j) + 1) {
st[i][j] = min(st[i][j - 1], st[i + (1 << (j - 1))][j - 1]);
}
rep (i, 1, m) {
auto [l, r, v] = lim[i];
if (que(l, r) != v) return cout << "-1\n", void();
}
sort(c + 1, c + m + 1), tot = unique(c + 1, c + m + 1) - c - 1;
rep (i, 1, tot) vec[i].clear(), pos[i].clear();
ll ans = 0;
rep (i, 1, n) if (mx[i] != inf) {
if (a[i] < mx[i]) ans += mx[i] - a[i], a[i] = mx[i];
int w = lower_bound(c + 1, c + tot + 1, mx[i]) - c;
pos[w].emplace_back(i);
}
rep (i, 1, m) {
auto [l, r, v] = lim[i];
v = lower_bound(c + 1, c + tot + 1, v) - c;
vec[v].emplace_back(l, r);
}
rep (i, 1, tot) if (SZ(vec[i])) {
int w = SZ(pos[i]);
rep (j, 1, w) val[j] = a[pos[i][j - 1]] - c[i];
rep (j, 1, w) tlim[i] = 0;
pii qp = pii(w, w);
for (auto &[l, r] : vec[i]) {
l = lower_bound(ALL(pos[i]), l) - pos[i].begin() + 1;
r = upper_bound(ALL(pos[i]), r) - pos[i].begin();
if (l > r) return cout << "-1", void();
chkmx(tlim[r + 1], l - 1), qp = pii(l, r);
}
rep (j, 1, w) chkmx(tlim[j], tlim[j - 1]);
rep (j, 1, w) dp[i] = 1e18;
multiset<ll> S;
int pos = 0;
S.emplace(0);
rep (j, 1, w) {
while (pos < tlim[j]) {
S.erase(S.find(dp[pos]));
pos++;
}
dp[j] = *S.begin() + val[j];
S.emplace(dp[j]);
}
ll mn = 1e18;
rep (j, qp.fi, qp.se) chkmn(mn, dp[j]);
ans += mn;
}
cout << ans << '\n';
}
int main() {
cin.tie(nullptr) -> ios::sync_with_stdio(false);
int t; cin >> t;
while (t--) work();
}
詳細信息
Test #1:
score: 100
Accepted
time: 4ms
memory: 52744kb
input:
1 3 2 2023 40 41 1 1 2022 2 3 39
output:
2
result:
ok 1 number(s): "2"
Test #2:
score: -100
Wrong Answer
time: 817ms
memory: 124176kb
input:
1000 100 100 1 35141686 84105222 84105220 7273527 178494861 178494861 112519027 77833654 77833656 261586535 278472336 278472336 261586536 416361017 416361017 426649080 323519513 278472337 420127821 420127823 420127823 482516531 434108818 420127821 631535744 615930922 546346921 546346920 546346920 70...
output:
45 44 34 33 43 40 42 44 45 47 40 53 761 49 44 53 40 59 51 42 44 49 39 49 48 55 49 42 38 41 38 49 52 40 56 41 41 41 37 46 42 46 42 44 709 750 43 48 45 49 43 37 48 50 39 42 49 50 46 44 35 45 39 36 51 40 42 42 32 50 47 44 43 43 43 40 38 41 37 44 42 29 40 44 48 44 45 40 39 41 42 37 43 48 44 41 42 41 42 ...
result:
wrong answer 1st numbers differ - expected: '49', found: '45'