mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-22 16:06:04 -05:00
50 lines
1.1 KiB
C
50 lines
1.1 KiB
C
|
// SPDX-License-Identifier: GPL-2.0
|
||
|
#include <linux/union_find.h>
|
||
|
|
||
|
/**
|
||
|
* uf_find - Find the root of a node and perform path compression
|
||
|
* @node: the node to find the root of
|
||
|
*
|
||
|
* This function returns the root of the node by following the parent
|
||
|
* pointers. It also performs path compression, making the tree shallower.
|
||
|
*
|
||
|
* Returns the root node of the set containing node.
|
||
|
*/
|
||
|
struct uf_node *uf_find(struct uf_node *node)
|
||
|
{
|
||
|
struct uf_node *parent;
|
||
|
|
||
|
while (node->parent != node) {
|
||
|
parent = node->parent;
|
||
|
node->parent = parent->parent;
|
||
|
node = parent;
|
||
|
}
|
||
|
return node;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* uf_union - Merge two sets, using union by rank
|
||
|
* @node1: the first node
|
||
|
* @node2: the second node
|
||
|
*
|
||
|
* This function merges the sets containing node1 and node2, by comparing
|
||
|
* the ranks to keep the tree balanced.
|
||
|
*/
|
||
|
void uf_union(struct uf_node *node1, struct uf_node *node2)
|
||
|
{
|
||
|
struct uf_node *root1 = uf_find(node1);
|
||
|
struct uf_node *root2 = uf_find(node2);
|
||
|
|
||
|
if (root1 == root2)
|
||
|
return;
|
||
|
|
||
|
if (root1->rank < root2->rank) {
|
||
|
root1->parent = root2;
|
||
|
} else if (root1->rank > root2->rank) {
|
||
|
root2->parent = root1;
|
||
|
} else {
|
||
|
root2->parent = root1;
|
||
|
root1->rank++;
|
||
|
}
|
||
|
}
|