/ SeriousOJ /

Record Detail

Wrong Answer


  
# Status Time Cost Memory Cost
#1 Accepted 1ms 532.0 KiB
#2 Wrong Answer 1ms 428.0 KiB
#3 Wrong Answer 1ms 532.0 KiB

Code

#include<bits/stdc++.h>
using namespace std;
#define int long long
#define endl "\n"
#define ff first
#define ss second
#define pb push_back
#define all(a) a.begin(),a.end()
#define rall(a) a.rbegin(),a.rend()
#define pii pair<int,int>
#define Fast ios_base::sync_with_stdio(false);cin.tie(NULL);cout.tie(NULL);
const int MOD = 1000000007;
const int INF = 1e18;
const int N = 2e5;
class SegmentTree {
public:
    int n;
    vector<pair<int,int>> tree;
    vector<int> arr;

    SegmentTree(vector<int>& v) {
        n = v.size() - 1;
        arr = v;
        tree.assign(4*n, {-INF, -1});
        build(1, 1, n);
    }

    void update(int ind, int val) { update(1, 1, n, ind, val); }

    pair<int,int> query(int l, int r) { return query(1, 1, n, l, r); }

private:
    pair<int,int> merge(pair<int,int> a, pair<int,int> b) {
        if (a.first > b.first) return a;
        if (b.first > a.first) return b;
        return (a.second < b.second ? a : b);
    }

    void build(int node, int start, int end) {
        if (start == end) {
            tree[node] = {arr[start], start};
        } else {
            int mid = (start + end) / 2;
            build(2*node, start, mid);
            build(2*node+1, mid+1, end);
            tree[node] = merge(tree[2*node], tree[2*node+1]);
        }
    }

    void update(int node, int start, int end, int ind, int val) {
        if (ind < start || ind > end) return;
        if (start == end) {
            if(tree[node].first < val)
                tree[node] = {val, start};
            else if(tree[node].first == val)
                tree[node] = {val, max(start,ind)};
        } else {
            int mid = (start + end) / 2;
            if (ind <= mid) update(2*node, start, mid, ind, val);
            else update(2*node+1, mid+1, end, ind, val);
            tree[node] = merge(tree[2*node], tree[2*node+1]);
        }
    }

    pair<int,int> query(int node, int start, int end, int l, int r) {
        if (r < start || end < l) return {-INF, -1}; 
        if (l <= start && end <= r) return tree[node];
        int mid = (start + end) / 2;
        auto left = query(2*node, start, mid, l, r);
        auto right = query(2*node+1, mid+1, end, l, r);
        return merge(left, right);
    }
};

void solve(int tc){
    int n; cin >> n;
    vector<int>a(n),b(n);
    for(int i=0;i<n;i++)cin >> a[i];
    for(int i=0;i<n;i++)cin >> b[i];
    vector<int>tmp(n+1);
    SegmentTree seg(tmp);
    vector<int>dp(n),in(n);
    int mxx = 0;
    for(int i=0;i<n;i++){
        auto [mx , ind] = seg.query(1,a[i]-1);
        if(ind != -1){
            dp[i] = mx + b[i];
            in[i] = ind;
        }
        else {
            dp[i] = b[i];
            in[i] = -1;
        }
        seg.update(a[i],dp[i]);
        mxx = max(mxx , dp[i]);
    }
    vector<int>lowest(n+1,-1);
    int index = 0;
    for(int i=0;i<n;i++){
        if(in[i]==-1){
            lowest[a[i]] = max(lowest[a[i]],i);
        }
        else {
            lowest[a[i]] = max(lowest[a[i]],lowest[in[i]]);
        }
        if(dp[i]==mxx)index = max(index,lowest[a[i]]);
    }
    cout << (n-index) << endl;
}
int32_t main(){
    Fast
    int t=1;
    cin >> t;
    for(int tc=1;tc<=t;tc++)
        solve(tc);
    return 0;
}

Information

Submit By
Type
Submission
Problem
P1224 Maximize the max
Contest
LUCC Presents Intra LU Junior Programming Contest - Replay
Language
C++17 (G++ 13.2.0)
Submit At
2025-09-02 17:30:32
Judged At
2025-09-02 17:30:32
Judged By
Score
1
Total Time
1ms
Peak Memory
532.0 KiB