Submission #287944

#TimeUsernameProblemLanguageResultExecution timeMemory
287944PeppaPigDischarging (NOI20_discharging)C++14
20 / 100
196 ms4344 KiB
#include <bits/stdc++.h>

#define long long long

using namespace std;

const int N = 1e6 + 5;

struct CHT {
    struct line {
        long m, c;
        line(long m, long c) : m(m), c(c) {}
        long f(long x) { return m * x + c; }
    };
    int ptr = 0;
    vector<line> vec;

    bool bad(line a, line b, line c) {
        return (c.c - a.c) * (a.m - b.m) < (b.c - a.c) * (a.m - c.m);
    }

    void add(long m, long c) {
        line l(m, c);
        while(vec.size() > 1 && bad(vec[(int)vec.size() - 2], vec.back(), l))
            vec.pop_back();
        vec.emplace_back(l);
    }

    long get_ans(long x) {
        while(ptr + 1 < (int)vec.size() && vec[ptr + 1].f(x) < vec[ptr].f(x)) 
            ++ptr;
        return vec[ptr].f(x);
    }
} hull;

int n, A[N];
long dp[N];
vector<int> stk;

int main() {
    scanf("%d", &n);
    for(int i = n; i; i--) scanf("%d", A + i);

    for(int i = 1; i <= n; i++) {
        while(!stk.empty() && A[stk.back()] <= A[i])
            stk.pop_back();
        stk.emplace_back(i);
    }
    for(int i = 0; i < (int)stk.size(); i++) {
        hull.add(A[stk[i]], dp[i - 1]);
        dp[i] = hull.get_ans(stk[i]);
    }

    printf("%lld\n", dp[(int)stk.size() - 1]);

    return 0;
}

Compilation message (stderr)

Discharging.cpp: In function 'int main()':
Discharging.cpp:41:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   41 |     scanf("%d", &n);
      |     ~~~~~^~~~~~~~~~
Discharging.cpp:42:33: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   42 |     for(int i = n; i; i--) scanf("%d", A + i);
      |                            ~~~~~^~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...