summaryrefslogtreecommitdiff
path: root/graphs/piscine/stack
diff options
context:
space:
mode:
authorMartial Simon <msimon_fr@hotmail.com>2025-09-15 01:08:27 +0200
committerMartial Simon <msimon_fr@hotmail.com>2025-09-15 01:08:27 +0200
commitc9b6b9a5ca082fe7c1b6f58d7713f785a9eb6a5c (patch)
tree3e4f42f93c7ae89a364e4d51fff6e5cec4e55fa9 /graphs/piscine/stack
add: graphs et rushs
Diffstat (limited to 'graphs/piscine/stack')
-rw-r--r--graphs/piscine/stack/stack.c30
-rw-r--r--graphs/piscine/stack/stack.h14
2 files changed, 44 insertions, 0 deletions
diff --git a/graphs/piscine/stack/stack.c b/graphs/piscine/stack/stack.c
new file mode 100644
index 0000000..0498abc
--- /dev/null
+++ b/graphs/piscine/stack/stack.c
@@ -0,0 +1,30 @@
+#include "stack.h"
+
+#include <stdlib.h>
+
+struct stack *stack_push(struct stack *s, int e)
+{
+ struct stack *new = malloc(sizeof(struct stack));
+ new->data = e;
+ new->next = NULL;
+
+ new->next = s;
+ return new;
+}
+
+struct stack *stack_pop(struct stack *s)
+{
+ if (s == NULL)
+ {
+ return NULL;
+ }
+
+ struct stack *res = s->next;
+ free(s);
+ return res;
+}
+
+int stack_peek(struct stack *s)
+{
+ return s->data;
+}
diff --git a/graphs/piscine/stack/stack.h b/graphs/piscine/stack/stack.h
new file mode 100644
index 0000000..bd5dd24
--- /dev/null
+++ b/graphs/piscine/stack/stack.h
@@ -0,0 +1,14 @@
+#ifndef STACK_H
+#define STACK_H
+
+struct stack
+{
+ int data;
+ struct stack *next;
+};
+
+struct stack *stack_push(struct stack *s, int e);
+struct stack *stack_pop(struct stack *s);
+int stack_peek(struct stack *s);
+
+#endif /* !STACK_H */