QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#820443#4598. DarnassusSGColinAC ✓330ms184372kbC++201.7kb2024-12-18 21:27:572024-12-18 21:28:05

Judging History

你现在查看的是最新测评结果

  • [2024-12-18 21:28:05]
  • 评测
  • 测评结果:AC
  • 用时:330ms
  • 内存:184372kb
  • [2024-12-18 21:27:57]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
using ll = long long;

#define fr first
#define sc second
#define mp make_pair
#define pb push_back
#define pii pair<int, int>

inline int rd() {
    int x = 0;
    bool f = 0;
    char c = getchar();
    for (; !isdigit(c); c = getchar()) f |= (c == '-');
    for (; isdigit(c); c = getchar()) x = x * 10 + (c ^ 48);
    return f ? -x : x;
}

#define N 50007

int f[N], p[N], q[N];

vector<pii> e[N];

inline int find(int x) {return x == f[x] ? x : f[x] = find(f[x]);}

inline int Abs(int x) {return x < 0 ? -x : x;}

inline void work() {
    int n = rd();
    for (int i = 1; i <= n; ++i) {
        f[i] = i; p[i] = rd(); q[p[i]] = i;
        e[i].clear();
    }
    int lim = sqrt(n) + 1;
    for (int i = 1; i <= n; ++i) {
        for (int j = max(1, i - lim), w; j < i; ++j) {
            if ((w = (i - j) * Abs(p[j] - p[i])) > n) continue;
            e[w].pb(mp(i, j));
        }
        for (int j, w, pj = max(1, p[i] - lim); pj < p[i]; ++pj) {
            j = q[pj];
            if (Abs(q[pj] - i) <= lim) continue;
            if ((w = (p[i] - pj) * Abs(j - i)) > n) continue;
            e[w].pb(mp(i, j)); 
        }
    }
    ll ans = 0;
    int cnt = n - 1;
    for (int i = 1; i <= n; ++i) {
        for (auto cur : e[i]) {
            int u = cur.fr, v = cur.sc;
            if (find(u) != find(v)) {
                --cnt;
                f[find(u)] = find(v);
                ans += i;
            }
            if (!cnt) break;
        }
        if (!cnt) break;
    }
    printf("%lld\n", ans);
}

int main() {
    for (int t = rd(); t; --t) work();
    return 0;
}

詳細信息

Test #1:

score: 100
Accepted
time: 330ms
memory: 184372kb

input:

5
50000
37763 49860 5765 19637 25267 12594 48787 14155 47404 5524 39461 31259 25877 30705 2684 7916 11685 39034 33744 43465 9933 2403 35987 7114 26874 22167 9016 15866 8799 1644 12470 30017 38907 46034 9522 31054 8591 20733 49457 46805 12191 40590 14403 5658 6721 2458 15939 12811 27626 33040 47408 5...

output:

99246830
99608266
99997
49998
98832945

result:

ok 5 lines