/ SeriousOJ /

Record Detail

Memory Exceeded


  
# Status Time Cost Memory Cost
#1 Accepted 1ms 536.0 KiB
#2 Memory Exceeded ≥290ms ≥256.016 MiB
#3 Memory Exceeded ≥286ms ≥256.016 MiB

Code

#include <bits/stdc++.h>
using namespace std;
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
using namespace __gnu_pbds;
template <typename T>
using ordered_set1 = tree<long long, null_type, less_equal<long long>, rb_tree_tag, tree_order_statistics_node_update>;
#define op()                      \
    ios_base::sync_with_stdio(0); \
    cin.tie(0);                   \
    cout.tie(0);
#define yes cout << "YES\n";
#define no cout << "NO\n";
#define gcd(a, b) __gcd(a, b)
#define lcm(a, b) ((a * b) / gcd(a, b))
#define PI 2.0 * acos(0.0)
#define Dpos(n) fixed << setprecision(n)

typedef long long ll;
typedef long double ld;
typedef vector<ll> vl;
typedef pair<ll, ll> pll;
typedef pair<int, int> pii;
const ll MOD = 1e9 + 7;
const ll N = 1e5 + 1;

ll dsu_find(ll node, vl &par)
{
    if (par[node] == -1)
        return node;
    return par[node] = dsu_find(par[node], par);
}
void dsu_union_by_level(ll node1, ll node2, vl &par, vl &level)
{
    ll leader1 = dsu_find(node1, par);
    ll leader2 = dsu_find(node2, par);
    if (level[leader1] > level[leader2])
        par[leader2] = leader1;
    else if (level[leader1] < level[leader2])
        par[leader1] = leader2;
    else
    {
        par[leader1] = leader2;
        level[leader2]++;
    }
}
void solve()
{
    ll n, q, i, x, y, ans = 0;
    cin >> n >> q;
    vl par(n + 1, -1), level(n + 1, 0), v1(n + 1);
    for (i = 1; i <= n; i++)
    {
        cin >> v1[i];
    }
    for (i = 1; i <= q; i++)
    {
        cin >> x >> y;
        dsu_union_by_level(x, y, par, level);
    }
    for (i = 1; i <= n; i++)
    {
        if (dsu_find(i, par) == dsu_find(v1[i], par))
            ans++;
    }
    cout << ans << endl;
}
int main()
{
    op() int tc = 1;
    cin >> tc;

    for (int t = 1; t <= tc; t++)
    {
        // cout << "Case " << t << ": ";
        solve();
    }
}

Information

Submit By
Type
Submission
Problem
P1119 Maximizing Fixed Points
Contest
Happy New Year 2025
Language
C++17 (G++ 13.2.0)
Submit At
2025-01-02 16:06:34
Judged At
2025-01-02 16:06:34
Judged By
Score
5
Total Time
≥290ms
Peak Memory
≥256.016 MiB