diff options
| author | Charles <sircharlesaze@gmail.com> | 2019-07-26 23:17:36 +0200 |
|---|---|---|
| committer | Charles <sircharlesaze@gmail.com> | 2019-07-26 23:17:36 +0200 |
| commit | 8ec5431354bdb582455e8c32758098c5a0fdada2 (patch) | |
| tree | 480c68814f822439850029df0e0249a2cafb8177 /exam_final/rendu/sort_list | |
| parent | 475449dd4b1f3308bac6f72c34d87812216a0738 (diff) | |
| download | piscine-8ec5431354bdb582455e8c32758098c5a0fdada2.tar.gz piscine-8ec5431354bdb582455e8c32758098c5a0fdada2.tar.bz2 piscine-8ec5431354bdb582455e8c32758098c5a0fdada2.zip | |
exam final
Diffstat (limited to 'exam_final/rendu/sort_list')
| -rwxr-xr-x | exam_final/rendu/sort_list/sort_list.c | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/exam_final/rendu/sort_list/sort_list.c b/exam_final/rendu/sort_list/sort_list.c new file mode 100755 index 0000000..62c173b --- /dev/null +++ b/exam_final/rendu/sort_list/sort_list.c @@ -0,0 +1,49 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* sort_list.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: exam <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2019/07/26 13:11:16 by exam #+# #+# */ +/* Updated: 2019/07/26 13:33:27 by exam ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include <stdlib.h> +#include "list.h" + +static int sorted(t_list *lst, int (*cmp)(int, int)) +{ + if (lst == NULL) + return (1); + while (lst->next != NULL) + { + if ((*cmp)(lst->data, lst->next->data) == 0) + return (0); + lst = lst->next; + } + return (1); +} + +t_list *sort_list(t_list* lst, int (*cmp)(int, int)) +{ + t_list *cursor; + int tmp; + + while (!sorted(lst, cmp)) + { + cursor = lst; + while (cursor->next != NULL) + { + if ((*cmp)(cursor->data, cursor->next->data) == 0) + { + tmp = cursor->data; + cursor->data = cursor->next->data; + cursor->next->data = tmp; + } + cursor = cursor->next; + } + } + return (lst); +} |
