diff options
| author | Charles <sircharlesaze@gmail.com> | 2020-04-26 21:04:43 +0200 |
|---|---|---|
| committer | Charles <sircharlesaze@gmail.com> | 2020-04-26 21:04:43 +0200 |
| commit | a3c962abbcdae671b886c4c76ddb9bb8ac27c958 (patch) | |
| tree | 7039b39f9fa56b9ad6e3b1c347fb5b77c049cada /src/bt/ft_btsorted_insert.c | |
| parent | 65c5d5157e890e9f9445a94fb2d7f660e5492d8e (diff) | |
| download | libft-a3c962abbcdae671b886c4c76ddb9bb8ac27c958.tar.gz libft-a3c962abbcdae671b886c4c76ddb9bb8ac27c958.tar.bz2 libft-a3c962abbcdae671b886c4c76ddb9bb8ac27c958.zip | |
Added ft_btsorted_insert, ft_btsorted_search, Red-black tree struct (not tested)
Diffstat (limited to 'src/bt/ft_btsorted_insert.c')
| -rw-r--r-- | src/bt/ft_btsorted_insert.c | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/src/bt/ft_btsorted_insert.c b/src/bt/ft_btsorted_insert.c new file mode 100644 index 0000000..12c0cde --- /dev/null +++ b/src/bt/ft_btsorted_insert.c @@ -0,0 +1,38 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_btsorted_insert.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: charles <charles.cabergs@gmail.com> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/04/26 19:10:36 by charles #+# #+# */ +/* Updated: 2020/04/26 19:19:24 by charles ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft_bt.h" + +/* +** \brief Insert a data in a binary search tree so that it stays sorted +** \param tree Tree where data is inserted +** \param data Data to insert +** \param cmp Comparison function +** \return The new root or NULL if a new node couldn't be allocated +*/ + +t_ftbt *ft_btsorted_insert(t_ftbt *tree, void *data, int (*cmp)(void*, void*)) +{ + if (tree == NULL) + return (ft_btnew(data)); + if (cmp(data, tree->data) < 0) + { + if (ft_btsorted_insert(tree->left, data, cmp) == NULL) + return (NULL); + } + else + { + if (ft_btsorted_insert(tree->right, data, cmp) == NULL) + return (NULL); + } + return (tree); +} |
