ref: 2bef4dfb50ec69cff1bc0569b76a7eb10115f576
dir: /dsf.c/
/* * dsf.c: two small functions to handle a disjoint set forest, * which is a data structure useful in any solver which has to * worry about avoiding closed loops. */ #include "puzzles.h" int dsf_canonify(int *dsf, int val) { int v2 = val; while (dsf[val] != val) val = dsf[val]; while (v2 != val) { int tmp = dsf[v2]; dsf[v2] = val; v2 = tmp; } return val; } void dsf_merge(int *dsf, int v1, int v2) { v1 = dsf_canonify(dsf, v1); v2 = dsf_canonify(dsf, v2); dsf[v2] = v1; }