QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#640359 | #415. 最小生成树 | Zhou_JK | 100 ✓ | 125ms | 15740kb | C++23 | 1.4kb | 2024-10-14 11:21:39 | 2024-10-14 11:21:40 |
Judging History
answer
#include<iostream>
#include<cstdio>
#include<vector>
#include<algorithm>
using namespace std;
struct Union_Set
{
int n;
vector<int>fa;
Union_Set(int _n):n(_n)
{
fa=vector<int>(_n);
for(int i=0;i<_n;i++)
fa[i]=i;
}
void init(int _n)
{
n=_n;
fa.resize(n);
for(int i=0;i<n;i++)
fa[i]=i;
return;
}
int getf(int v)
{
if(v==fa[v]) return v;
else return fa[v]=getf(fa[v]);
}
bool merge(int u,int v)
{
int fu=getf(u),fv=getf(v);
if(fu!=fv)
{
fa[fv]=fu;
return true;
}
else return false;
}
};
long long minimum_spanning_tree(int n,vector<tuple<int,int,int>>edge)
{
sort(edge.begin(),edge.end(),[](const tuple<int,int,int> &a,const tuple<int,int,int> &b){return get<2>(a)<get<2>(b);});
Union_Set us(n);
long long sum=0;
for(int i=0;i<(int)edge.size();i++)
{
auto &[u,v,w]=edge[i];
if(us.merge(u,v)) sum+=w;
}
return sum;
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(nullptr),cout.tie(nullptr);
int n,m;
cin>>n>>m;
vector<tuple<int,int,int>>edge(m);
for(int i=0;i<m;i++)
{
int u,v,w;
cin>>u>>v>>w;
u--,v--;
edge[i]={u,v,w};
}
cout<<minimum_spanning_tree(n,edge);
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Pretests
Final Tests
Test #1:
score: 10
Accepted
time: 0ms
memory: 3592kb
input:
1 0
output:
0
result:
ok answer is '0'
Test #2:
score: 10
Accepted
time: 87ms
memory: 14868kb
input:
1 500000 1 1 436085873 1 1 289134331 1 1 95168426 1 1 809912668 1 1 912905316 1 1 51427205 1 1 808052925 1 1 168547991 1 1 469573116 1 1 7523372 1 1 700424384 1 1 329491017 1 1 886380039 1 1 92596215 1 1 870407506 1 1 420928567 1 1 29439913 1 1 851970613 1 1 595343843 1 1 150074451 1 1 981248098 1 1...
output:
0
result:
ok answer is '0'
Test #3:
score: 10
Accepted
time: 1ms
memory: 3624kb
input:
1049 1095 37 1027 185663189 439 923 842401821 92 68 172561838 108 320 929023969 537 284 451497914 161 836 18296000 101 14 582350247 82 947 633276668 555 731 321285985 282 946 133823187 549 982 59411620 19 151 982845654 961 22 185979994 201 958 42654715 178 446 121754463 100 386 87537747 492 486 2228...
output:
459312924580
result:
ok answer is '459312924580'
Test #4:
score: 10
Accepted
time: 97ms
memory: 14708kb
input:
1677 500000 1010 1055 334171722 32 548 496908773 1662 273 215127528 1596 969 799111789 993 895 816193284 335 56 975688725 1537 1674 694838017 512 1006 84989138 487 1094 77423013 1131 522 260247889 32 1581 652804125 1472 1609 861174323 1083 230 236457705 1009 593 692730522 709 284 647880265 936 1598 ...
output:
3426870407
result:
ok answer is '3426870407'
Test #5:
score: 10
Accepted
time: 95ms
memory: 14720kb
input:
4782 500000 401 2704 143282494 408 742 221495274 2487 2740 328112333 1471 3347 678117943 2369 3844 94084087 4137 629 771103 1506 2976 377332399 3856 3529 15354521 977 1747 267860558 2561 1837 234002816 1947 1191 447985398 2575 3486 210906740 321 1319 879712756 3660 3019 926744290 4492 528 110850246 ...
output:
20391912348
result:
ok answer is '20391912348'
Test #6:
score: 10
Accepted
time: 55ms
memory: 9380kb
input:
100000 250000 11249 63248 716981925 77587 45081 715237577 40869 43888 384028427 68447 21259 718879057 15416 4835 542698454 86984 39250 200243926 38485 9822 321829618 68650 80338 208779180 93995 71720 970100731 62306 65602 758670337 12962 93202 405549936 11239 70788 481995017 65169 11656 137255256 93...
output:
19768912676568
result:
ok answer is '19768912676568'
Test #7:
score: 10
Accepted
time: 59ms
memory: 9316kb
input:
100000 250000 58087 98694 276928916 81020 20563 474360924 54330 72482 965233532 69316 62625 693679792 68391 25019 626212979 66635 9065 208396713 18722 31967 29636156 18804 17430 126344131 52091 61058 813889563 22524 92717 616323226 91592 59352 7003125 39568 15009 745751969 59457 33731 34864625 3185 ...
output:
19671766809300
result:
ok answer is '19671766809300'
Test #8:
score: 10
Accepted
time: 45ms
memory: 8644kb
input:
200000 199999 65210 94695 20344717 27677 60426 947830254 44160 166001 68537440 144553 10242 174779136 72796 113802 266364597 1858 24797 628448494 194099 76945 666582594 133683 17237 128244232 152149 91422 110103130 150169 10041 739399998 136455 75250 7894691 81174 102926 26871471 27780 63438 7883747...
output:
94124014988825
result:
ok answer is '94124014988825'
Test #9:
score: 10
Accepted
time: 125ms
memory: 15740kb
input:
200000 500000 46671 50310 339946279 111950 44341 976219244 183028 30375 283623377 119684 483 278812425 123223 173434 86847632 53396 67926 343986583 195715 85791 872435965 51759 67385 324694963 132645 146330 74109089 142363 58800 508205119 151247 105471 160455427 97528 133772 68416120 33125 33151 102...
output:
39818560453301
result:
ok answer is '39818560453301'
Test #10:
score: 10
Accepted
time: 117ms
memory: 15544kb
input:
200000 500000 45588 17449 500297001 167443 90625 840063438 184162 31916 123322602 75130 105595 80124915 4990 23835 842648585 198193 138933 377398791 61179 68315 899014505 170138 8312 214877618 130847 183955 648135341 186493 178082 135732043 34104 128022 298311436 180739 90096 241294500 90919 4640 35...
output:
39679281240808
result:
ok answer is '39679281240808'