#ifndef C_IMPLEMENT_UNION_FIND_H
#define C_IMPLEMENT_UNION_FIND_H

#include "stdio.h"
#include "stdlib.h"
#include "vector"
#include "iostream"


class Tree_node{
public:
  int x, y;
  Tree_node* parent;
  int rank;
  int children;
  bool marked;
  Tree_node (int x, int y);
  ~Tree_node();
};

Tree_node* Make_set (int value);
Tree_node* Union (Tree_node* x, Tree_node* y);
Tree_node* Link (Tree_node* x, Tree_node* y);
Tree_node* Find_set (Tree_node* x);
Tree_node* Recursive_find_set (Tree_node* x, int c);
void Delete (Tree_node* x);
void Clean (Tree_node* x);
void Free (Tree_node* x);


#endif //C_IMPLEMENT_UNION_FIND_H