社区讨论

50pts 球条玄关

P14915「QFOI R3」算法竞赛参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@mjpp0e3u
此快照首次捕获于
2025/12/28 20:15
2 个月前
此快照最后确认于
2026/01/01 09:25
2 个月前
查看原帖
CPP
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 100005;
const ll INF = 1e18;
ll n, k, d, a[N], dp[N], tr[N * 4];
void upd(int u, int l, int r, int p, ll v){
    if(l == r){tr[u] = v; return;}
    int m = (l + r) / 2;
    if(p <= m) upd(u * 2, l, m, p, v);
    else upd(u * 2 + 1, m + 1, r, p, v);
    tr[u] = min(tr[u * 2], tr[u * 2 + 1]);
}
ll que(int u, int l, int r, int ql, int qr){
    if(ql > qr) return INF;
    if(ql <= l && r <= qr) return tr[u];
    int m = (l + r) / 2;
    ll res = INF;
    if(ql <= m) res = min(res, que(u * 2, l, m, ql, qr));
    if(qr > m) res = min(res, que(u * 2 + 1, m + 1, r, ql, qr));
    return res;
}
int main(){
    ios::sync_with_stdio(false);
    cin.tie(0);
    cin >> n >> k >> d;
    for(int i = 1; i <= n; i++) cin >> a[i];
    sort(a + 1, a + n + 1);
    for(int i = 0; i < N * 4; i++) tr[i] = INF;
    upd(1, 0, n, 0, 0);
    for(int i = 1; i <= n; i++){
        ll low = a[i] - (ll)(k-1) * d;
        int pos = lower_bound(a + 1, a + n + 1, low) - a;
        int L = max(0, max(pos - 1, i - (int)k));
        int R = i - 1;
        ll mn = que(1, 0, n, L, R);
        dp[i] = mn + 1;
        upd(1, 0, n, i, dp[i]);
    }
    cout << dp[n] * k - n << endl;
    return 0;
}

回复

0 条回复,欢迎继续交流。

正在加载回复...