aboutsummaryrefslogtreecommitdiff
path: root/exam_final/rendu/sort_list
diff options
context:
space:
mode:
authorCharles <sircharlesaze@gmail.com>2019-07-26 23:17:36 +0200
committerCharles <sircharlesaze@gmail.com>2019-07-26 23:17:36 +0200
commit8ec5431354bdb582455e8c32758098c5a0fdada2 (patch)
tree480c68814f822439850029df0e0249a2cafb8177 /exam_final/rendu/sort_list
parent475449dd4b1f3308bac6f72c34d87812216a0738 (diff)
downloadpiscine-8ec5431354bdb582455e8c32758098c5a0fdada2.tar.gz
piscine-8ec5431354bdb582455e8c32758098c5a0fdada2.tar.bz2
piscine-8ec5431354bdb582455e8c32758098c5a0fdada2.zip
exam final
Diffstat (limited to 'exam_final/rendu/sort_list')
-rwxr-xr-xexam_final/rendu/sort_list/sort_list.c49
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);
+}