QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#625400#7003. Rikka with Minimum Spanning Treesucup-team5071#WA 781ms7412kbC++201.7kb2024-10-09 19:04:422024-10-09 19:04:43

Judging History

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

  • [2024-10-09 19:04:43]
  • 评测
  • 测评结果:WA
  • 用时:781ms
  • 内存:7412kb
  • [2024-10-09 19:04:42]
  • 提交

answer

#include <bits/stdc++.h>

using namespace std;


struct edge{
    int u,v;
    unsigned long long w;
    bool operator <(const edge& other) const {
        return w < other.w;
    }
} e[100001];
const unsigned long long P = 1e9+7;
unsigned long long k1 , k2;
unsigned long long xorShift128Plus () {
unsigned long long k3 = k1 , k4 = k2;
k1 = k4;
k3 ^= k3 << 23;
k2 = k3 ^ k4 ^ (k3 >> 17) ^ (k4 >> 26) ;
return k2 + k4;
}
int n, m, u [100001] , v [100001];
unsigned long long w [100001];
void gen () {
scanf ("%d%d%llu%llu", &n, &m, &k1 , &k2);
for ( int i = 1; i <= m; ++i) {
u[i] = xorShift128Plus () % n + 1;
v[i] = xorShift128Plus () % n + 1;
w[i] = xorShift128Plus () ;
}
}

int fa[100001];
int get_fa(int x){
    if (fa[x] == x) return x;
    return fa[x] = get_fa(fa[x]);
}
bool merge(int x,int y){
    int fx = get_fa(x);
    int fy = get_fa(y);
    if (fx == fy) return false;
    fa[fx] = fy; 
    return true;
}


void solve(){
    gen();
    for (int i = 1; i <= n; ++i){
        fa[i] = i;
    }
    for (int i = 1; i <= m; ++i){
        e[i].u = u[i];
        e[i].v = v[i];
        e[i].w = w[i];
    }
    sort(e+1,e+m+1);
    unsigned long long ans = 0;
    for (int i = 1; i <= m; ++i){
        // if (i <= 10) {
        //     cout << e[i].u << " " << e[i].v << " " << e[i].w << "\n";
        // }
        if (merge(e[i].u,e[i].v)){
            
            ans += e[i].w%P;
            ans %= P;
        }
    }
    printf("%llu\n",ans);
}
int main(){
    // ios_base::sync_with_stdio(0);
    // cin.tie(0);
    int T;
    // cin >> T;
    scanf("%d",&T);
    while(T--){
        solve();
    }

}

详细

Test #1:

score: 100
Accepted
time: 9ms
memory: 7036kb

input:

1
2 100000 123456789 987654321

output:

575673759

result:

ok single line: '575673759'

Test #2:

score: -100
Wrong Answer
time: 781ms
memory: 7412kb

input:

100
17085 100000 676466090490 878574984049
24353 100000 685976930882 229685257786
4 100000 471961964055 157860429766
15406 100000 410376133349 828755231175
1 100000 809050431491 785471826497
1796 100000 218311747353 410830725634
93449 100000 761721499751 355474414706
3214 100000 277812617111 2429646...

output:

436638303
216567542
405150678
355979925
0
50713419
918381795
512195596
338362921
521086329
139607202
289558312
831627251
345103943
788519192
306890280
168133083
308823048
813378518
25758919
733644946
851485656
196406140
128088006
80292565
315609167
632805182
745061180
939817511
995073785
854970966
9...

result:

wrong answer 2nd lines differ - expected: '0', found: '216567542'