QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#700607#8941. Even or Odd Spanning Treerikka_lyly#WA 119ms3736kbC++204.1kb2024-11-02 13:12:552024-11-02 13:12:55

Judging History

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

  • [2024-11-02 13:12:55]
  • 评测
  • 测评结果:WA
  • 用时:119ms
  • 内存:3736kb
  • [2024-11-02 13:12:55]
  • 提交

answer

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

#define ll long long
#define ull unsigned long long
#define MAXN 200010
#define int ll

namespace BCJ
{
    int fa[MAXN];
    void init(int n)
    {
        for (int i = 1; i <= n; i++)
        {
            fa[i] = i;
        }
    }
    int find(int x)
    {
        return fa[x] == x ? x : fa[x] = find(fa[x]);
    }
    void unity(int x, int y)
    {
        fa[find(x)] = find(y);
    }
};

void solve()
{
    int n, m;
    cin >> n >> m;
    int logn = log2(n) + 3;
    vector<pair<int, pair<int, int>>> eds(m);
    vector<bool> tag(m);
    for (int i = 0; i < m; i++)
    {
        cin >> eds[i].second.first >> eds[i].second.second >> eds[i].first;
    }
    vector<vector<pair<int, int>>> adj(n + 1);
    BCJ::init(n);
    sort(eds.begin(), eds.end());
    int ans = 0;
    int toted = 0;
    for (int i = 0; i < m; i++)
    {
        auto &[w, uv] = eds[i];
        auto &[u, v] = uv;
        if(BCJ::find(u) != BCJ::find(v))
        {
            // cerr << "u=" << u << " v=" << v << endl;
            ans += w;
            BCJ::unity(u, v);
            adj[u].push_back({v, w});
            adj[v].push_back({u, w});
            tag[i] = 1;
            toted++;
        }
    }
    if(toted != n - 1)
    {
        cout << -1 << " " << -1 << '\n';
        return;
    }

    vector<vector<int>> fa(n + 1, vector<int>(logn, 0));
    vector<vector<array<int, 2>>> mxnum(n + 1, vector<array<int, 2>>(logn, {0, 0}));
    vector<int> deep(n + 1);
    auto dfs = [&](auto self, int cur, int father, int lstval) -> void
    {
        deep[cur] = deep[father] + 1;
        fa[cur][0] = father;
        mxnum[cur][0][lstval % 2] = lstval;
        for (int i = 1; i < logn; i++)
        {
            fa[cur][i] = fa[fa[cur][i - 1]][i - 1];
            mxnum[cur][i][0] = max(mxnum[cur][i - 1][0], mxnum[fa[cur][i - 1]][i - 1][0]);
            mxnum[cur][i][1] = max(mxnum[cur][i - 1][1], mxnum[fa[cur][i - 1]][i - 1][1]);
        }
        for (auto &[to, w] : adj[cur])
        {
            if(to == father)
                continue;
            self(self, to, cur, w);
        }
    };
    dfs(dfs, 1, 0, 0);

    auto getmxnum = [&](int x, int y) -> array<int, 2>
    {
        if(deep[x] > deep[y])
            swap(x, y);
        array<int, 2> ans = {0, 0};
        int temp = deep[y] - deep[x];
        for (int i = 0; i < logn; i++)
        {
            if(temp >> i & 1)
            {
                ans[0] = max(ans[0], mxnum[y][i][0]);
                ans[1] = max(ans[1], mxnum[y][i][1]);
                y = fa[y][i];
            }
        }
        if(x == y)
            return ans;
        for (int i = logn - 1; i >= 0; i--)
        {
            if(fa[x][i] != fa[y][i])
            {
                ans[0] = max(ans[0], mxnum[x][i][0]);
                ans[1] = max(ans[1], mxnum[x][i][1]);
                ans[0] = max(ans[0], mxnum[y][i][0]);
                ans[1] = max(ans[1], mxnum[y][i][1]);
                x = fa[x][i];
                y = fa[y][i];
            }
        }
        ans[0] = max(ans[0], mxnum[x][0][0]);
        ans[1] = max(ans[1], mxnum[x][0][1]);
        ans[0] = max(ans[0], mxnum[y][0][0]);
        ans[1] = max(ans[1], mxnum[y][0][1]);
        return ans;
    };

    int newans = ans;
    for (int i = 0; i < m; i++)
    {
        if(tag[i])
            continue;
        auto &[w, uv] = eds[i];
        auto &[u, v] = uv;
        auto newmx = getmxnum(u, v);
        if(newmx[!(w % 2)] != 0)
            newans = max(newans, ans + w - newmx[!(w % 2)]);
    }
    if(newans == ans)
    {
        if(ans % 2 == 0)
            cout << ans << " " << -1 << '\n';
        else
            cout << -1 << " " << ans << '\n';
    }
    else
    {
        assert(ans % 2 != newans % 2);
        if(ans % 2 == 0)
            cout << ans << " " << newans << '\n';
        else
            cout << newans << " " << ans << '\n';
    }
}

signed main()
{
    ios::sync_with_stdio(false);
    cin.tie(0), cout.tie(0);
    int t;
    cin >> t;
    while (t--)
    {
        solve();
    }
}

詳細信息

Test #1:

score: 100
Accepted
time: 0ms
memory: 3736kb

input:

3
2 1
1 2 5
3 1
1 3 1
4 4
1 2 1
1 3 1
1 4 1
2 4 2

output:

-1 5
-1 -1
4 3

result:

ok 6 numbers

Test #2:

score: -100
Wrong Answer
time: 119ms
memory: 3716kb

input:

10000
16 50
1 2 649251632
2 3 605963017
3 4 897721528
4 5 82446151
5 6 917109168
6 7 79647183
7 8 278566178
7 9 573504723
3 10 679859251
8 11 563113083
1 12 843328546
10 13 594049160
11 14 997882839
7 15 569431750
2 16 244494799
16 7 960172373
13 4 317888322
13 3 446883598
9 3 678142319
5 8 43208692...

output:

3140067932 3941554631
1262790434 2124445815
1263932600 2177809565
2128472300 1180186165
2248358640 3162318131
4696867870 3738936375
2011213264 1058677117
4144333014 3402127725
2081445350 1187873655
1395482806 2324672773
3456885934 4302070719
3943951826 4702420591
2479987500 3216859457
2909126794 388...

result:

wrong answer 2nd numbers differ - expected: '3159441841', found: '3941554631'