Submission #997952


Source Code Expand

#include <iostream>
#include <fstream>
#include <sstream>

#include <vector>
#include <set>
#include <bitset>
#include <map>
#include <deque>
#include <string>

#include <algorithm>
#include <numeric>

#include <cstdio>
#include <cassert>
#include <cstdlib>
#include <cstring>
#include <ctime>
#include <cmath>

#define pb push_back
#define pbk pop_back
#define mp make_pair
#define fs first
#define sc second
#define all(x) (x).begin(), (x).end()
#define foreach(i, a) for (__typeof((a).begin()) i = (a).begin(); i != (a).end(); ++i)
#define len(a) ((int) (a).size())

#ifdef CUTEBMAING
#define eprintf(...) fprintf(stderr, __VA_ARGS__)
#else
#define eprintf(...) 42
#endif

#define rank hurank

using namespace std;

typedef long long int64;
typedef long double ld;
typedef unsigned long long lint;

const int inf = (1 << 30) - 1;
const int64 linf = (1ll << 62) - 1;
const int N = 1e6 + 100;

int n, m, k;
int a[N];

int64 dp[N];

int parent[N], rank[N];
int64 value[N];

inline int findSet(int v) {
    if (parent[v] != v) {
        return parent[v] = findSet(parent[v]);
    }
    return v;
}

inline void unite(int a, int b) {
    a = findSet(a);
    b = findSet(b);
    if (a == b) {
        return ;
    }
    if (rank[a] == rank[b]) {
        rank[a]++;
    }
    if (rank[a] > rank[b]) {
        swap(a, b);
    }
    parent[a] = b;
}

int main() {
#ifdef XCODE
    freopen("input.txt", "r", stdin);
    freopen("output.txt", "w", stdout);
#endif
    cin >> n >> m >> k;
    for (int i = 0; i < n; i++) {
        scanf("%d", &a[i]);
    }
    for (int i = 0; i < k; i++) {
        for (int j = n - 1; j >= 0; j--) {
            dp[j + 1] = dp[j];
        }
        dp[0] = 0;
        for (int j = 0; j < n; j++) {
            parent[j] = j;
            rank[j] = 0;
        }
        vector<pair<int64, int>> stack;
        for (int j = 0; j < n; j++) {
            pair<int64, int> curValue(dp[j] + 1ll * (i + 1) * a[j], j);
            while (len(stack) > 0 && stack.back().fs <= curValue.fs) {
                unite(stack.back().sc, curValue.sc);
                stack.pbk();
            }
            value[findSet(curValue.sc)] = curValue.fs;
            stack.pb(curValue);
            dp[j] = value[findSet(max(0, j - m))];
        }
    }
    cout << *max_element(dp, dp + n) << endl;
    return 0;
}

Submission Info

Submission Time
Task A - Struck Out
User darinflar
Language C++14 (GCC 5.4.1)
Score 0
Code Size 2429 Byte
Status WA
Exec Time 858 ms
Memory 3072 KB

Compile Error

./Main.cpp: In function ‘int main()’:
./Main.cpp:86:27: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
         scanf("%d", &a[i]);
                           ^

Judge Result

Set Name Sample subtask1 subtask2 subtask3 All
Score / Max Score 0 / 0 0 / 100 0 / 200 0 / 300 0 / 100
Status
AC × 3
AC × 8
WA × 2
AC × 10
WA × 2
AC × 19
WA × 2
AC × 34
WA × 9
Set Name Test Cases
Sample sample_1.txt, sample_2.txt, sample_3.txt
subtask1 sample_2.txt, subtask_1_1.txt, subtask_1_2.txt, subtask_1_3.txt, subtask_1_4.txt, subtask_1_5.txt, subtask_1_6.txt, subtask_1_7.txt, subtask_1_8.txt, subtask_1_9.txt
subtask2 sample_1.txt, sample_2.txt, sample_3.txt, subtask_2_1.txt, subtask_2_2.txt, subtask_2_3.txt, subtask_2_4.txt, subtask_2_5.txt, subtask_2_6.txt, subtask_2_7.txt, subtask_2_8.txt, subtask_2_9.txt
subtask3 sample_1.txt, sample_2.txt, sample_3.txt, subtask_2_1.txt, subtask_2_2.txt, subtask_2_3.txt, subtask_2_4.txt, subtask_2_5.txt, subtask_2_6.txt, subtask_2_7.txt, subtask_2_8.txt, subtask_2_9.txt, subtask_3_1.txt, subtask_3_2.txt, subtask_3_3.txt, subtask_3_4.txt, subtask_3_5.txt, subtask_3_6.txt, subtask_3_7.txt, subtask_3_8.txt, subtask_3_9.txt
All sample_1.txt, sample_2.txt, sample_3.txt, subtask_1_1.txt, subtask_1_2.txt, subtask_1_3.txt, subtask_1_4.txt, subtask_1_5.txt, subtask_1_6.txt, subtask_1_7.txt, subtask_1_8.txt, subtask_1_9.txt, subtask_2_1.txt, subtask_2_2.txt, subtask_2_3.txt, subtask_2_4.txt, subtask_2_5.txt, subtask_2_6.txt, subtask_2_7.txt, subtask_2_8.txt, subtask_2_9.txt, subtask_3_1.txt, subtask_3_2.txt, subtask_3_3.txt, subtask_3_4.txt, subtask_3_5.txt, subtask_3_6.txt, subtask_3_7.txt, subtask_3_8.txt, subtask_3_9.txt, subtask_4_1.txt, subtask_4_10.txt, subtask_4_11.txt, subtask_4_12.txt, subtask_4_13.txt, subtask_4_2.txt, subtask_4_3.txt, subtask_4_4.txt, subtask_4_5.txt, subtask_4_6.txt, subtask_4_7.txt, subtask_4_8.txt, subtask_4_9.txt
Case Name Status Exec Time Memory
sample_1.txt AC 3 ms 256 KB
sample_2.txt AC 3 ms 256 KB
sample_3.txt AC 3 ms 256 KB
subtask_1_1.txt AC 3 ms 256 KB
subtask_1_2.txt AC 63 ms 512 KB
subtask_1_3.txt AC 633 ms 2944 KB
subtask_1_4.txt AC 7 ms 384 KB
subtask_1_5.txt AC 28 ms 2944 KB
subtask_1_6.txt WA 3 ms 256 KB
subtask_1_7.txt AC 224 ms 2944 KB
subtask_1_8.txt AC 637 ms 2944 KB
subtask_1_9.txt WA 5 ms 256 KB
subtask_2_1.txt AC 3 ms 256 KB
subtask_2_2.txt AC 3 ms 256 KB
subtask_2_3.txt AC 3 ms 256 KB
subtask_2_4.txt AC 3 ms 256 KB
subtask_2_5.txt WA 3 ms 256 KB
subtask_2_6.txt WA 3 ms 256 KB
subtask_2_7.txt AC 3 ms 256 KB
subtask_2_8.txt AC 3 ms 256 KB
subtask_2_9.txt AC 3 ms 256 KB
subtask_3_1.txt AC 87 ms 2944 KB
subtask_3_2.txt AC 95 ms 2944 KB
subtask_3_3.txt AC 92 ms 2944 KB
subtask_3_4.txt AC 77 ms 2432 KB
subtask_3_5.txt AC 6 ms 384 KB
subtask_3_6.txt AC 57 ms 2944 KB
subtask_3_7.txt AC 82 ms 2944 KB
subtask_3_8.txt AC 11 ms 512 KB
subtask_3_9.txt AC 97 ms 2944 KB
subtask_4_1.txt AC 773 ms 3072 KB
subtask_4_10.txt WA 664 ms 2944 KB
subtask_4_11.txt WA 858 ms 2944 KB
subtask_4_12.txt WA 850 ms 2944 KB
subtask_4_13.txt WA 825 ms 2944 KB
subtask_4_2.txt WA 808 ms 2944 KB
subtask_4_3.txt AC 656 ms 2944 KB
subtask_4_4.txt AC 771 ms 2944 KB
subtask_4_5.txt AC 676 ms 2944 KB
subtask_4_6.txt AC 66 ms 2944 KB
subtask_4_7.txt AC 433 ms 2944 KB
subtask_4_8.txt AC 753 ms 2944 KB
subtask_4_9.txt AC 361 ms 2944 KB