Advertisement
saske_7

temp.cpp

Nov 5th, 2017
75
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.55 KB | None | 0 0
  1. #include<bits/stdc++.h>
  2. using namespace std ;
  3.  
  4.  
  5. #define M 500000
  6. #define pii pair<int , int >
  7. #define mp make_pair
  8. #define pf printf
  9. #define sf scanf
  10. #define sf1(a ) scanf("%d",&a)
  11. #define pb push_back
  12. #define sf2(a, b) scanf("%d%d",&a ,&b)
  13. #define rep(i,n) for(i = 0 ; i< n ;i++ )
  14.  
  15. int par[M] ,  num ;
  16.  
  17. struct vertex {
  18.     int u  , v , w ;
  19.  
  20. };
  21.  
  22. vector <vertex >node;
  23. bool comp(vertex p , vertex q ){
  24.     return p.w < q.w ;
  25.  
  26. }
  27.  
  28. int find(int a ){
  29.     if(par[a ] ==  a ) return a ;
  30.     else return par[a ] =  find(par[a ]);
  31.  
  32. }
  33.  
  34. void make(int a , int b ){
  35.     int u = find(a );
  36.     int v = find(b);
  37.     if(u != v ) par[u] =  v ;
  38.  
  39. }
  40.  
  41.  
  42. int mst(){
  43.     int i , j ,k ;
  44.     rep(i , num + 5) par[i] = i ;
  45.     sort(node.begin() , node.end() , comp);
  46.     int cost =  0;
  47.  
  48.     for(i = 0 ; i < node.size() ; i++){
  49.         if(find(node[i].u ) != find(node[i].v ) )
  50.         {
  51.             make(node[i].u , node[i].v );
  52.             cost += node[i].w ;
  53.  
  54.  
  55.         }
  56.  
  57.     }
  58.  
  59.     return cost;
  60. }
  61.  
  62.  
  63. int main(){
  64. //    freopen("in.txt","r",stdin);
  65. //    freopen("out.txt","w",stdout);
  66.  
  67.     int i , j ,k ,tc , print =  0;
  68.     int n , ed , cs = 0;
  69.     scanf("%d",&tc);
  70.     while(tc--)
  71.     {
  72.  
  73.  
  74.         int cost ;
  75.         scanf("%d%d%d",&n ,&ed ,&cost);
  76.         num = n ;
  77.         node.clear();
  78.  
  79.         while(ed--){
  80.             vertex var ;
  81.             scanf("%d%d%d",&var.u , &var.v , &var.w );
  82.             node.pb(var);
  83.  
  84.         }
  85.  
  86.         k = mst();
  87.     map<int , int > m;
  88.     int count = 0;
  89.  
  90.     for(i= 1 ; i<= num ;i++){
  91.         int x =  find(i);
  92.         if( m.find(x) == m.end()){
  93.             m[x ] =  1;
  94.             count++;
  95.         }
  96.     }
  97.  
  98.     pf("Case #%d: %d %d\n",++cs, k+ count*cost , count);
  99.  
  100.     }
  101.  
  102.  
  103.     return 0 ;
  104. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement