답안 #1004479

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1004479 2024-06-21T09:19:48 Z Nelt Sirni (COCI17_sirni) C++17
84 / 140
1751 ms 786432 KB
#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
#define ll int
#define endl "\n"
 
using namespace std;
using namespace __gnu_pbds;
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
template<class T> using ordered_set = tree<T, null_type, less_equal<T>, rb_tree_tag, tree_order_statistics_node_update>;
const ll N = 1e5 + 5, MAX = 1e7 + 5;
struct Dsu
{
    ll n, ans;
    vector<ll> dsu;
    Dsu(ll sz = 1)
    {
        n = sz;
        ans = n;
        dsu.resize(n + 1, 0);
        init();
    }
    void init()
    {
        for (ll i = 0; i <= n; i++)
            dsu[i] = -1;
    }
    bool Union(ll x, ll y)
    {
        x = repr(x), y = repr(y);
        if (x == y)
            return false;
        if (dsu[x] < dsu[y])
            swap(x, y);
        ans--;
        dsu[y] += dsu[x];
        dsu[x] = y;
        return true;
    }
    ll repr(ll x)
    {
        if (dsu[x] < 0)
            return x;
        return dsu[x] = repr(dsu[x]);
    }
    ll query()
    {
        return ans;
    }
    ll size(ll x)
    {
        return -dsu[repr(x)];
    }
};
ll freq[MAX], ind[MAX];
vector<ll> consider[MAX];
vector<pair<ll, ll>> e[MAX];
ll best[N];
ll f(ll x, ll y)
{
    return min(x % y, y % x);
}
void solve()
{
    ll n;
    cin >> n;
    ll p[n];
    for (ll &i : p) cin >> i;
    long long ans = 0;
    {
        set<ll> s;
        for (ll i : p) s.insert(i);
        n = 0;
        for (ll i : s) p[n++] = i;
    }
    for (ll i = 0; i <= p[n - 1]; i++) ind[i] = -1;
    for (ll i : p) freq[i]++;
    for (ll i = 0; i < n; i++) ind[p[i]] = i;
    for (ll i = 1; i <= p[n - 1]; i++) freq[i] += freq[i - 1];
    for (ll i = 0; i < n; i++)
        for (ll j = p[i]; j <= p[n - 1]; j += p[i]) consider[j].push_back(i);
    Dsu dsu(n);
    for (ll i = 0; i < n - 1; i++) e[f(p[i], p[i + 1])].push_back(make_pair(i, i + 1));
    for (ll w = p[n - 1]; w > 0; w--)
    {
        ll pos = lower_bound(p, p + n, w) - p;
        if (pos < n)
        for (ll i : consider[w]) if (p[pos] < w + p[i]) e[p[pos] - w].push_back(make_pair(pos, i));
        consider[w].clear();
    }
    // for (ll i = 0; i < n; i++) for (ll j = 0; j < n; j++) e[f(p[i], p[j])].push_back(make_pair(i, j));
    for (ll i = 0; i <= p[n - 1]; i++) for (auto [a, b] : e[i]) ans += dsu.Union(a, b) * i;
    cout << ans << endl;
}
 
int main()
{
    ios_base::sync_with_stdio(0);
    cin.tie(0);
    ll t = 1;
    // precomp();
    // cin >> t;
    for (ll cs = 1; cs <= t; cs++)
        solve();
    // cerr << "\nTime elapsed: " << clock() * 1000.0 / CLOCKS_PER_SEC << " ms\n";
}
# 결과 실행 시간 메모리 Grader output
1 Correct 289 ms 548428 KB Output is correct
2 Correct 533 ms 609972 KB Output is correct
3 Correct 304 ms 549200 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 173 ms 470420 KB Output is correct
2 Runtime error 557 ms 786432 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 279 ms 548692 KB Output is correct
2 Correct 271 ms 548212 KB Output is correct
3 Correct 296 ms 548688 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 304 ms 506144 KB Output is correct
2 Correct 527 ms 553428 KB Output is correct
3 Correct 450 ms 523404 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 254 ms 484432 KB Output is correct
2 Correct 367 ms 524112 KB Output is correct
3 Correct 296 ms 499372 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 406 ms 526700 KB Output is correct
2 Correct 664 ms 577484 KB Output is correct
3 Correct 370 ms 518844 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 204 ms 480036 KB Output is correct
2 Correct 665 ms 578940 KB Output is correct
3 Correct 399 ms 521616 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 595 ms 598216 KB Output is correct
2 Runtime error 926 ms 786432 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 626 ms 610356 KB Output is correct
2 Runtime error 1090 ms 786432 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 347 ms 556496 KB Output is correct
2 Runtime error 1751 ms 786432 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -