码迷,mamicode.com
首页 > 其他好文 > 详细

并查集

时间:2018-08-29 14:01:34      阅读:155      评论:0      收藏:0      [点我收藏+]

标签:bsp   i++   turn   printf   pre   initial   lease   memset   connected   

/*并查集*/
#include<stdio.h>

int *a;
int *sz;
int count;  //the number of connected component

//union two connected components with weights
void union_two_points(int p, int q)
{
  int i = root(p);
  int j = root(q);
  if(i == j) return;
  if(sz[i] < sz[j]) 
  {
     a[i] = j;
     sz[j] += sz[i];
  }
  else
  {
     a[j] = i;
     sz[i] += sz[j];
  }
  count--;
}


//test if p and q are connected
int connected(int p, int q)
{
  return root[p] == root[q];
}


//find the root point
int root(int p)
{
   while(p != a[p])
   {
      p = a[p];
   }
   return p;
}


int main()
{
   int T;
   printf("Please input the number of points:");
   scanf("%d",&T);

   count = T;
   a = (int*)malloc(sizeof(int)*T);
   sz = (int*)malloc(sizeof(int)*T);

   memset(sz,1,T*sizeof(int));      //set the size array
   //initial the array 
   for(int i=0;i<T;i++)
   {
      a[i] = i;
   }

   /*
   operation
   */
}

 

并查集

标签:bsp   i++   turn   printf   pre   initial   lease   memset   connected   

原文地址:https://www.cnblogs.com/dzy521/p/9552893.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!