QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#865877#7003. Rikka with Minimum Spanning TreestarjenAC ✓770ms7424kbC++201.7kb2025-01-22 03:43:152025-01-22 03:43:20

Judging History

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

  • [2025-01-22 03:43:20]
  • 评测
  • 测评结果:AC
  • 用时:770ms
  • 内存:7424kb
  • [2025-01-22 03:43:15]
  • 提交

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;
    int cnt=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)){
            cnt++;
            ans += e[i].w%P;
            ans %= P;
        }
    }
    if(cnt==n-1)printf("%llu\n",ans);
    else printf("0\n");
}
int main(){
    // ios_base::sync_with_stdio(0);
    // cin.tie(0);
    int T;
    // cin >> T;
    scanf("%d",&T);
    while(T--){
        solve();
    }

}

这程序好像有点Bug,我给组数据试试?

詳細信息

Test #1:

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

input:

1
2 100000 123456789 987654321

output:

575673759

result:

ok single line: '575673759'

Test #2:

score: 0
Accepted
time: 770ms
memory: 7424kb

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
0
405150678
355979925
0
50713419
0
512195596
338362921
0
0
289558312
831627251
345103943
788519192
306890280
168133083
308823048
813378518
25758919
733644946
851485656
0
0
0
315609167
632805182
745061180
0
995073785
854970966
0
0
0
423134815
0
867689881
500810440
0
0
0
945701987
0
0
0
1959...

result:

ok 100 lines