diff options
| author | Charles <sircharlesaze@gmail.com> | 2020-02-10 02:16:49 +0100 |
|---|---|---|
| committer | Charles <sircharlesaze@gmail.com> | 2020-02-10 02:16:49 +0100 |
| commit | 0acdc4fec5cae4e619d0f4f8bd67e171bffa110e (patch) | |
| tree | 3c77b003ae67d130272b61cc910bf10a3a3b5f9c /src/lst/ft_lstsort.c | |
| parent | 329e7a3bde7f206414fe89c9b3ca12d1fc1e1b29 (diff) | |
| download | libft-0acdc4fec5cae4e619d0f4f8bd67e171bffa110e.tar.gz libft-0acdc4fec5cae4e619d0f4f8bd67e171bffa110e.tar.bz2 libft-0acdc4fec5cae4e619d0f4f8bd67e171bffa110e.zip | |
Added ft_lstsort, ft_lstsorted_merge
Diffstat (limited to 'src/lst/ft_lstsort.c')
| -rw-r--r-- | src/lst/ft_lstsort.c | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/src/lst/ft_lstsort.c b/src/lst/ft_lstsort.c new file mode 100644 index 0000000..883604f --- /dev/null +++ b/src/lst/ft_lstsort.c @@ -0,0 +1,40 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstsort.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: cacharle <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/10 01:53:55 by cacharle #+# #+# */ +/* Updated: 2020/02/10 02:09:28 by cacharle ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft_lst.h" + +void ft_lstsort(t_ftlst **begin_list, int (*cmp)(void *, void*)) +{ + t_ftlst *fast; + t_ftlst *slow; + t_ftlst *middle; + + if (begin_list == NULL || *begin_list == NULL + || (*begin_list)->next == NULL) + return ; + fast = (*begin_list)->next; + slow = *begin_list; + while (fast != NULL) + { + fast = fast->next; + if (fast != NULL) + { + fast = fast->next; + slow = slow->next; + } + } + middle = slow->next; + slow->next = NULL; + ft_lstsort(begin_list, cmp); + ft_lstsort(&middle, cmp); + *begin_list = ft_lstsorted_merge(*begin_list, middle, cmp); +} |
