Commit 563ea1f5 authored by Xavier's avatar Xavier Committed by Tejun Heo

Documentation: Fix the compilation errors in union_find.rst

Fix the compilation errors and warnings caused by merging
Documentation/core-api/union_find.rst and
Documentation/translations/zh_CN/core-api/union_find.rst.
Signed-off-by: default avatarXavier <xavier_qy@163.com>
Signed-off-by: default avatarTejun Heo <tj@kernel.org>
parent ab031252
...@@ -49,6 +49,7 @@ Library functionality that is used throughout the kernel. ...@@ -49,6 +49,7 @@ Library functionality that is used throughout the kernel.
wrappers/atomic_t wrappers/atomic_t
wrappers/atomic_bitops wrappers/atomic_bitops
floating-point floating-point
union_find
Low level entry and exit Low level entry and exit
======================== ========================
......
...@@ -16,9 +16,11 @@ of disjoint sets. The primary operations supported by union-find are: ...@@ -16,9 +16,11 @@ of disjoint sets. The primary operations supported by union-find are:
Initialization: Resetting each element as an individual set, with Initialization: Resetting each element as an individual set, with
each set's initial parent node pointing to itself. each set's initial parent node pointing to itself.
Find: Determine which set a particular element belongs to, usually by Find: Determine which set a particular element belongs to, usually by
returning a “representative element” of that set. This operation returning a “representative element” of that set. This operation
is used to check if two elements are in the same set. is used to check if two elements are in the same set.
Union: Merge two sets into one. Union: Merge two sets into one.
As a data structure used to maintain sets (groups), union-find is commonly As a data structure used to maintain sets (groups), union-find is commonly
...@@ -63,7 +65,7 @@ operation, the tree with the smaller rank is attached under the tree with the ...@@ -63,7 +65,7 @@ operation, the tree with the smaller rank is attached under the tree with the
larger rank to maintain balance. larger rank to maintain balance.
Initializing union-find Initializing union-find
-------------------- -----------------------
You can complete the initialization using either static or initialization You can complete the initialization using either static or initialization
interface. Initialize the parent pointer to point to itself and set the rank interface. Initialize the parent pointer to point to itself and set the rank
...@@ -71,7 +73,9 @@ to 0. ...@@ -71,7 +73,9 @@ to 0.
Example:: Example::
struct uf_node my_node = UF_INIT_NODE(my_node); struct uf_node my_node = UF_INIT_NODE(my_node);
or or
uf_node_init(&my_node); uf_node_init(&my_node);
Find the Root Node of union-find Find the Root Node of union-find
......
...@@ -49,6 +49,7 @@ ...@@ -49,6 +49,7 @@
generic-radix-tree generic-radix-tree
packing packing
this_cpu_ops this_cpu_ops
union_find
======= =======
......
...@@ -3,21 +3,23 @@ ...@@ -3,21 +3,23 @@
:Original: Documentation/core-api/union_find.rst :Original: Documentation/core-api/union_find.rst
=========================== =============================
Linux中的并查集(Union-Find) Linux中的并查集(Union-Find)
=========================== =============================
:日期: 2024年6月21日 :日期: 2024年6月21日
:作者: Xavier <xavier_qy@163.com> :作者: Xavier <xavier_qy@163.com>
何为并查集,它有什么用? 何为并查集,它有什么用?
--------------------- ------------------------
并查集是一种数据结构,用于处理一些不交集的合并及查询问题。并查集支持的主要操作: 并查集是一种数据结构,用于处理一些不交集的合并及查询问题。并查集支持的主要操作:
初始化:将每个元素初始化为单独的集合,每个集合的初始父节点指向自身 初始化:将每个元素初始化为单独的集合,每个集合的初始父节点指向自身。
查询:查询某个元素属于哪个集合,通常是返回集合中的一个“代表元素”。这个操作是为 查询:查询某个元素属于哪个集合,通常是返回集合中的一个“代表元素”。这个操作是为
了判断两个元素是否在同一个集合之中。 了判断两个元素是否在同一个集合之中。
合并:将两个集合合并为一个。 合并:将两个集合合并为一个。
并查集作为一种用于维护集合(组)的数据结构,它通常用于解决一些离线查询、动态连通性和 并查集作为一种用于维护集合(组)的数据结构,它通常用于解决一些离线查询、动态连通性和
...@@ -37,7 +39,7 @@ Linux中的并查集(Union-Find) ...@@ -37,7 +39,7 @@ Linux中的并查集(Union-Find)
https://en.wikipedia.org/wiki/Disjoint-set_data_structure https://en.wikipedia.org/wiki/Disjoint-set_data_structure
并查集的Linux实现 并查集的Linux实现
---------------- ------------------
Linux的并查集实现在文件“lib/union_find.c”中。要使用它,需要 Linux的并查集实现在文件“lib/union_find.c”中。要使用它,需要
“#include <linux/union_find.h>”。 “#include <linux/union_find.h>”。
...@@ -48,22 +50,25 @@ Linux的并查集实现在文件“lib/union_find.c”中。要使用它,需 ...@@ -48,22 +50,25 @@ Linux的并查集实现在文件“lib/union_find.c”中。要使用它,需
struct uf_node *parent; struct uf_node *parent;
unsigned int rank; unsigned int rank;
}; };
其中parent为当前节点的父节点,rank为当前树的高度,在合并时将rank小的节点接到rank大 其中parent为当前节点的父节点,rank为当前树的高度,在合并时将rank小的节点接到rank大
的节点下面以增加平衡性。 的节点下面以增加平衡性。
初始化并查集 初始化并查集
--------- -------------
可以采用静态或初始化接口完成初始化操作。初始化时,parent 指针指向自身,rank 设置 可以采用静态或初始化接口完成初始化操作。初始化时,parent 指针指向自身,rank 设置
为 0。 为 0。
示例:: 示例::
struct uf_node my_node = UF_INIT_NODE(my_node); struct uf_node my_node = UF_INIT_NODE(my_node);
uf_node_init(&my_node); uf_node_init(&my_node);
查找并查集的根节点 查找并查集的根节点
---------------- ------------------
主要用于判断两个并查集是否属于一个集合,如果根相同,那么他们就是一个集合。在查找过程中 主要用于判断两个并查集是否属于一个集合,如果根相同,那么他们就是一个集合。在查找过程中
会对路径进行压缩,提高后续查找效率。 会对路径进行压缩,提高后续查找效率。
...@@ -78,7 +83,7 @@ Linux的并查集实现在文件“lib/union_find.c”中。要使用它,需 ...@@ -78,7 +83,7 @@ Linux的并查集实现在文件“lib/union_find.c”中。要使用它,需
connected = 0; connected = 0;
合并两个并查集 合并两个并查集
------------- --------------
对于两个相交的并查集进行合并,会首先查找它们各自的根节点,然后根据根节点秩大小,将小的 对于两个相交的并查集进行合并,会首先查找它们各自的根节点,然后根据根节点秩大小,将小的
节点连接到大的节点下面。 节点连接到大的节点下面。
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment