Initial commit

This commit is contained in:
2026-01-09 15:20:33 +01:00
commit d0a9d550e5
31 changed files with 2248 additions and 0 deletions

55
Makefile Normal file
View File

@@ -0,0 +1,55 @@
# **************************************************************************** #
# #
# ::: :::::::: #
# Makefile :+: :+: :+: #
# +:+ +:+ +:+ #
# By: lejulien <lejulien@student.42.fr> +#+ +:+ +#+ #
# +#+#+#+#+#+ +#+ #
# Created: 2021/03/05 13:10:44 by lejulien #+# #+# #
# Updated: 2021/04/02 13:28:10 by lejulien ### ########.fr #
# #
# **************************************************************************** #
SRCS_UTILS = ./srcs/utils/ft_atoi.c ./srcs/utils/ft_putnbr_fd.c \
./srcs/utils/ft_putstr.c ./srcs/utils/ft_sqrt.c \
./srcs/utils/ft_itoa.c ./srcs/utils/ft_strcmp.c
SRCS_CHECKER = ./srcs/checker/checker.c ./srcs/checker/actions.c \
./srcs/checker/error.c ./srcs/checker/checker2.c \
./srcs/checker/entry.c ./srcs/checker/check_stack.c \
./srcs/checker/parse_entry.c
SRCS_PUSH_SWAP = ./srcs/push_swap/push_swap.c ./srcs/push_swap/actions.c \
./srcs/push_swap/error.c ./srcs/push_swap/action2.c \
./srcs/push_swap/check_stack.c ./srcs/push_swap/bubblesort.c \
./srcs/push_swap/sort.c ./srcs/push_swap/push_swap2.c \
./srcs/push_swap/chunked.c ./srcs/push_swap/goto.c \
./srcs/push_swap/count.c ./srcs/push_swap/last_max.c \
./srcs/push_swap/sort_chunk.c
OBJS_UTILS = $(SRCS_UTILS:.c=.o)
OBJS_CHECKER = $(SRCS_CHECKER:.c=.o)
OBJS_PUSH_SWAP = $(SRCS_PUSH_SWAP:.c=.o)
NAME = checker
GCC = gcc
FLAGS = -Wall -Wextra -Werror
all: $(NAME)
.PHONY: clean fclean re
$(NAME): $(OBJS_UTILS) $(OBJS_CHECKER) $(OBJS_PUSH_SWAP)
gcc -o $(NAME) $(FLAGS) $(OBJS_UTILS) $(OBJS_CHECKER)
gcc -o push_swap $(FLAGS) $(OBJS_UTILS) $(OBJS_PUSH_SWAP)
clean:
rm -f $(OBJS_CHECKER) $(OBJS_PUSH_SWAP) $(OBJS_UTILS)
fclean: clean
rm -f $(NAME)
rm -f push_swap
re: fclean all
%.o: %.c
$(GCC) -c $< -o $(<:.c=.o)

108
srcs/checker/actions.c Normal file
View File

@@ -0,0 +1,108 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* actions.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <lejulien@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/05 15:57:06 by lejulien #+# #+# */
/* Updated: 2021/03/16 15:32:51 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include <stdlib.h>
#include "checker.h"
int
add_to_stack(t_stack **stack, int value, int is_disp)
{
t_stack *new;
t_stack *ptr;
ptr = *stack;
if (!(new = malloc(sizeof(t_stack))))
return (1);
new->value = value;
new->next = NULL;
new->disp = is_disp;
if (*stack == NULL)
{
*stack = new;
return (0);
}
while (ptr->next != NULL)
ptr = ptr->next;
ptr->next = new;
return (0);
}
void
push(t_stack **a_stack, t_stack **b_stack)
{
t_stack *ptr;
if (*a_stack == NULL)
return ;
ptr = *a_stack;
*a_stack = ptr->next;
ptr->next = *b_stack;
*b_stack = ptr;
}
void
swap(t_stack **stack)
{
t_stack *a;
t_stack *b;
a = *stack;
if (!a)
return ;
b = a->next;
if (!b)
return ;
*stack = b;
a->next = b->next;
b->next = a;
}
void
rotate(t_stack **stack)
{
t_stack *a;
t_stack *b;
a = *stack;
if (!a)
return ;
b = a->next;
if (!b)
return ;
while (b->next != NULL)
b = b->next;
*stack = a->next;
b->next = a;
a->next = NULL;
}
void
r_rotate(t_stack **stack)
{
t_stack *a;
t_stack *b;
a = *stack;
if (!a)
return ;
b = a->next;
if (!b)
return ;
while (b->next != NULL)
{
a = a->next;
b = b->next;
}
a->next = NULL;
b->next = *stack;
*stack = b;
}

View File

@@ -0,0 +1,44 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* check_stack.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/04/01 13:39:16 by lejulien #+# #+# */
/* Updated: 2021/04/01 13:40:34 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "checker.h"
#include <stdlib.h>
#include "../utils/utils.h"
void
check_stack(t_stack **stack)
{
t_stack *ptr;
int prev;
ptr = *stack;
if (ptr == NULL)
return (ft_putstr("KO\n"));
if (ptr->next == NULL)
{
ft_putstr("OK\n");
return ;
}
prev = ptr->value;
ptr = ptr->next;
while (ptr != NULL)
{
if (prev > ptr->value)
{
ft_putstr("KO\n");
return ;
}
prev = ptr->value;
ptr = ptr->next;
}
ft_putstr("OK\n");
}

110
srcs/checker/checker.c Normal file
View File

@@ -0,0 +1,110 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* checker.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <lejulien@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/05 13:01:57 by lejulien #+# #+# */
/* Updated: 2021/04/02 13:29:50 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "../utils/utils.h"
#include <unistd.h>
#include "checker.h"
#include <stdlib.h>
int
push_values_to_stack(t_stack **stack, char **av, int ac, int pos)
{
int i;
t_stack *b_stack;
t_stack *ptr;
b_stack = NULL;
i = pos;
while (i < ac)
{
if (add_to_stack(stack, ft_atoi(av[i]), pos))
return (ft_free_stacks(stack, &b_stack, 1));
i++;
}
ptr = *stack;
if (has_double(stack))
return (ft_free_stacks(stack, &b_stack, 1));
if (entry(stack, &b_stack))
return (ft_free_stacks(stack, &b_stack, 1));
return (ft_free_stacks(stack, &b_stack, 1) - 1);
}
static int
is_flag(char *str)
{
if (str[0] == '-' && str[1] == 'v')
return (1);
return (0);
}
int
check_flags(int ac, char **av)
{
int i;
i = 0;
if (ac > 2)
{
if (is_flag(av[1]))
i++;
}
return (1 + i);
}
int
check_num(int ac, char **av)
{
int i;
int j;
i = 1;
while (i < ac)
{
j = 0;
while (av[i][j] != '\0')
{
if (av[i][j] < '0' || av[i][j] > '9')
{
if (av[i][j] != '-')
return (1);
}
j++;
}
i++;
}
return (0);
}
int
check_max(int ac, char **av)
{
int i;
char *tmp;
int i_tmp;
i = 1;
while (i < ac)
{
if (av[i][0] == '\0')
return (1);
i_tmp = ft_atoi(av[i]);
tmp = ft_itoa(i_tmp);
if (i_tmp != 0 && my_strcmp(av[i], tmp))
{
free(tmp);
return (1);
}
free(tmp);
i++;
}
return (0);
}

40
srcs/checker/checker.h Normal file
View File

@@ -0,0 +1,40 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* checker.h :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/05 13:38:15 by lejulien #+# #+# */
/* Updated: 2021/04/01 18:24:46 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#ifndef CHECKER_H
# define CHECKER_H
typedef struct s_stack
{
int value;
int disp;
void *next;
} t_stack;
int add_to_stack(t_stack **stack, int value, int pos);
int ft_free_stacks(t_stack **a_stack, t_stack **b_stack, int ret);
void display_stack(t_stack **a_stack, t_stack **b_stack);
int has_double(t_stack **stack);
int entry(t_stack **a_stack, t_stack **b_stack);
void push(t_stack **a_stack, t_stack **b_stack);
void swap(t_stack **stack);
void rotate(t_stack **stack);
void r_rotate(t_stack **stack);
void check_stack(t_stack **stack);
int push_values_to_stack(t_stack **stack, char **av, int ac,
int pos);
int check_flags(int ac, char **av);
int check_num(int ac, char **av);
int check_max(int ac, char **av);
int parse_entry(char *str, t_stack **a_stack, t_stack **b_stack);
int ft_strlen(char *str);
#endif

58
srcs/checker/checker2.c Normal file
View File

@@ -0,0 +1,58 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* checker2.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/04/01 13:45:52 by lejulien #+# #+# */
/* Updated: 2021/04/01 13:52:35 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "checker.h"
#include "../utils/utils.h"
#include <stdlib.h>
int
is_number(char *c)
{
int i;
i = 0;
while (c[i] != '\0')
{
if (c[i] < '0' || c[i] > '9')
return (0);
i++;
}
return (1);
}
int
main(int ac, char **av)
{
t_stack *a_stack;
int flags;
a_stack = NULL;
if (ac > 1)
{
if (check_num(ac, av) || check_max(ac, av))
{
ft_putstr("Error\n");
return (1);
}
if (!(flags = check_flags(ac, av)))
{
ft_putstr("Error\n");
return (1);
}
if (push_values_to_stack(&a_stack, av, ac, flags))
{
ft_putstr("Error\n");
return (1);
}
}
return (0);
}

74
srcs/checker/entry.c Normal file
View File

@@ -0,0 +1,74 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* entry.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/04/01 13:53:40 by lejulien #+# #+# */
/* Updated: 2021/04/01 14:27:24 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "checker.h"
#include "../utils/utils.h"
#include <unistd.h>
#include <stdlib.h>
char
*add_char(char *src, char c)
{
char *ret;
int index;
index = 0;
if (src == NULL)
{
if (!(ret = malloc(2 * sizeof(char))))
return (NULL);
ret[0] = c;
ret[1] = '\0';
return (ret);
}
if (!(ret = malloc((ft_strlen(src) + 1) * sizeof(char))))
return (NULL);
while (src[index] != '\0')
{
ret[index] = src[index];
index++;
}
ret[index] = c;
ret[index + 1] = '\0';
free(src);
return (ret);
}
int
entry(t_stack **a_stack, t_stack **b_stack)
{
int run;
char c;
char *entry;
int ret;
run = 1;
entry = NULL;
while (run)
{
ret = read(0, &c, 1);
if (ret == -1 || ret == 0 || c == '\x4')
run = 0;
entry = add_char(entry, c);
if (c == '\n')
{
ret = parse_entry(entry, a_stack, b_stack);
free(entry);
if (ret == 1)
return (1);
entry = NULL;
}
}
free(entry);
(*b_stack != NULL) ? ft_putstr("KO\n") : check_stack(a_stack);
return (0);
}

64
srcs/checker/error.c Normal file
View File

@@ -0,0 +1,64 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* error.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/05 15:59:25 by lejulien #+# #+# */
/* Updated: 2021/04/01 13:40:58 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include <stdlib.h>
#include "checker.h"
#include "../utils/utils.h"
static void
ft_free_stack(t_stack **stack)
{
t_stack *tmp;
t_stack *nxt;
if (!*stack)
return ;
tmp = *stack;
while (tmp != NULL)
{
nxt = tmp->next;
free(tmp);
tmp = nxt;
}
*stack = NULL;
}
int
ft_free_stacks(t_stack **a_stack, t_stack **b_stack, int ret)
{
ft_free_stack(a_stack);
if (b_stack != NULL)
ft_free_stack(b_stack);
return (ret);
}
int
has_double(t_stack **stack)
{
t_stack *ptr1;
t_stack *ptr2;
ptr1 = *stack;
ptr2 = ptr1->next;
while (ptr1->next != NULL)
{
ptr2 = ptr1->next;
while (ptr2 != NULL)
{
if (ptr1->value == ptr2->value)
return (1);
ptr2 = ptr2->next;
}
ptr1 = ptr1->next;
}
return (0);
}

View File

@@ -0,0 +1,99 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* parse_entry.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/04/01 14:15:28 by lejulien #+# #+# */
/* Updated: 2021/04/01 14:16:49 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "checker.h"
#include "../utils/utils.h"
int
ft_strlen(char *str)
{
int i;
i = 0;
while (str[i] != '\0')
i++;
return (i);
}
int
ft_strcmp(char *src, char *dst)
{
int i;
i = 0;
if (ft_strlen(src) != ft_strlen(dst))
return (0);
while (src[i] != '\0')
{
if (src[i] != dst[i])
return (0);
i++;
}
return (1);
}
static int
parse_entry2(char *str, t_stack **a_stack, t_stack **b_stack)
{
if (ft_strcmp("ss\n", str))
{
swap(a_stack);
swap(b_stack);
return (1);
}
else if (ft_strcmp("ra\n", str))
{
rotate(a_stack);
return (1);
}
else if (ft_strcmp("rb\n", str))
{
rotate(b_stack);
return (1);
}
else if (ft_strcmp("rr\n", str))
{
rotate(a_stack);
rotate(b_stack);
}
return (0);
}
int
parse_entry(char *str, t_stack **a_stack, t_stack **b_stack)
{
if (ft_strcmp("pa\n", str))
push(b_stack, a_stack);
else if (ft_strcmp("pb\n", str))
push(a_stack, b_stack);
else if (ft_strcmp("sa\n", str))
swap(a_stack);
else if (ft_strcmp("sb\n", str))
swap(b_stack);
else if (ft_strcmp("rra\n", str))
r_rotate(a_stack);
else if (parse_entry2(str, a_stack, b_stack))
{
}
else if (ft_strcmp("rrb\n", str))
r_rotate(b_stack);
else if (ft_strcmp("rrr\n", str))
{
r_rotate(a_stack);
r_rotate(b_stack);
}
else if (ft_strcmp("\n", str))
return (0);
else
return (1);
return (0);
}

28
srcs/push_swap/action2.c Normal file
View File

@@ -0,0 +1,28 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* action2.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/04/01 14:52:29 by lejulien #+# #+# */
/* Updated: 2021/04/01 14:53:06 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "push_swap.h"
#include <stdlib.h>
void
stack_dup(t_stack **res, t_stack **src)
{
t_stack *ptr;
*res = NULL;
ptr = *src;
while (ptr)
{
add_to_stack(res, ptr->value, 0);
ptr = ptr->next;
}
}

110
srcs/push_swap/actions.c Normal file
View File

@@ -0,0 +1,110 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* actions.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <lejulien@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/05 15:57:06 by lejulien #+# #+# */
/* Updated: 2021/04/01 14:53:36 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include <stdlib.h>
#include "../utils/utils.h"
#include "push_swap.h"
int
add_to_stack(t_stack **stack, int value, int is_disp)
{
t_stack *new;
t_stack *ptr;
ptr = *stack;
if (!(new = malloc(sizeof(t_stack))))
return (1);
new->value = value;
new->next = NULL;
new->disp = is_disp;
new->part = 0;
if (*stack == NULL)
{
*stack = new;
return (0);
}
while (ptr->next != NULL)
ptr = ptr->next;
ptr->next = new;
return (0);
}
void
push(t_stack **a_stack, t_stack **b_stack)
{
t_stack *ptr;
if (*a_stack == NULL)
return ;
ptr = *a_stack;
*a_stack = ptr->next;
ptr->next = *b_stack;
*b_stack = ptr;
}
void
swap(t_stack **stack)
{
t_stack *a;
t_stack *b;
a = *stack;
if (!a)
return ;
b = a->next;
if (!b)
return ;
*stack = b;
a->next = b->next;
b->next = a;
}
void
rotate(t_stack **stack)
{
t_stack *a;
t_stack *b;
a = *stack;
if (!a)
return ;
b = a->next;
if (!b)
return ;
while (b->next != NULL)
b = b->next;
*stack = a->next;
b->next = a;
a->next = NULL;
}
void
r_rotate(t_stack **stack)
{
t_stack *a;
t_stack *b;
a = *stack;
if (!a)
return ;
b = a->next;
if (!b)
return ;
while (b->next != NULL)
{
a = a->next;
b = b->next;
}
a->next = NULL;
b->next = *stack;
*stack = b;
}

View File

@@ -0,0 +1,42 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* bubblesort.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/11 15:30:32 by lejulien #+# #+# */
/* Updated: 2021/03/26 15:13:01 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "push_swap.h"
#include "../utils/utils.h"
#include <stdlib.h>
void
bubble_sort(t_stack **stack, int ac)
{
t_stack *ptr1;
t_stack *ptr2;
t_stack *nill;
int i;
nill = NULL;
i = 0;
while (check_stack(stack))
{
ptr1 = *stack;
ptr2 = ptr1->next;
if (ptr1->value > ptr2->value)
swap(stack);
if (check_stack(stack))
rotate(stack);
i++;
if (i == (ac - 1))
{
rotate(stack);
i = 0;
}
}
}

View File

@@ -0,0 +1,125 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* check_stack.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/04/01 16:50:27 by lejulien #+# #+# */
/* Updated: 2021/04/01 17:42:34 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "push_swap.h"
#include <stdlib.h>
#include "../utils/utils.h"
int
check_stack(t_stack **stack)
{
t_stack *ptr;
int prev;
ptr = *stack;
if (ptr == NULL)
return (1);
if (ptr->next == NULL)
return (1);
prev = ptr->value;
ptr = ptr->next;
while (ptr != NULL)
{
if (prev > ptr->value)
return (1);
prev = ptr->value;
ptr = ptr->next;
}
return (0);
}
int
r_check_stack(t_stack **stack)
{
t_stack *ptr;
int prev;
ptr = *stack;
if (ptr == NULL)
return (1);
if (ptr->next == NULL)
return (1);
prev = ptr->value;
ptr = ptr->next;
while (ptr != NULL)
{
if (prev < ptr->value)
return (1);
prev = ptr->value;
ptr = ptr->next;
}
return (0);
}
int
biggest(t_stack **stack)
{
t_stack *ptr;
int val;
ptr = *stack;
val = ptr->value;
ptr = ptr->next;
while (ptr)
{
if (ptr->value > val)
val = ptr->value;
ptr = ptr->next;
}
return (val);
}
int
val_pos(int val, t_stack **stack)
{
int i;
t_stack *ptr;
i = 0;
ptr = *stack;
while (ptr)
{
if (val == ptr->value)
return (i);
i++;
ptr = ptr->next;
}
return (-1);
}
void
move_top(int val, t_stack **stack)
{
int length;
int pos;
length = part_length(stack, 0);
if (pos < (length / 2))
{
print_val("val = ", val);
while (pos <= (length / 2))
{
rotate(stack);
ft_putstr("ra\n");
pos++;
}
}
else
{
while (pos < length)
{
r_rotate(stack);
ft_putstr("rra\n");
pos++;
}
}
}

86
srcs/push_swap/chunked.c Normal file
View File

@@ -0,0 +1,86 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* chunked.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/26 15:26:29 by lejulien #+# #+# */
/* Updated: 2021/04/01 18:03:55 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "push_swap.h"
#include "../utils/utils.h"
#include <stdlib.h>
void
chunked(t_stack **stack, int nbr)
{
int size;
int i;
int part;
t_stack *ptr;
int start_part;
size = part_length(stack, 0);
size = size / nbr + 1;
ptr = *stack;
start_part = ptr->part;
while (nbr > 0)
{
i = 0;
ptr = NULL;
part = new_part(stack, &ptr);
while (i < size)
{
ptr = *stack;
ptr->part = part;
(ptr->next->part != start_part + 1) ? rotate(stack) : NULL;
i++;
}
nbr--;
}
rotate(stack);
}
static int
find_next_val(t_stack **stack, int val)
{
t_stack *ptr;
ptr = *stack;
while (ptr->value != biggest(stack))
ptr = ptr->next;
while (val < ptr->value)
{
ptr = ptr->next;
if (!ptr)
ptr = *stack;
}
return (ptr->value);
}
void
place_val(int val, t_stack **b_stack, t_stack **a_stack, int part)
{
if (*b_stack && val > smallest(b_stack) && val < biggest(b_stack))
ft_goto(b_stack, find_next_val(b_stack, val), "b");
else if (*b_stack)
ft_goto(b_stack, biggest(b_stack), "b");
push(a_stack, b_stack);
ft_putstr("pb\n");
}
static int
is_last_in_part(t_stack **a_stack, int part)
{
t_stack *ptr;
ptr = *a_stack;
while (ptr->next)
ptr = ptr->next;
if (ptr->part == part)
return (0);
return (1);
}

104
srcs/push_swap/count.c Normal file
View File

@@ -0,0 +1,104 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* count.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/04/01 17:39:08 by lejulien #+# #+# */
/* Updated: 2021/04/01 17:40:37 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "push_swap.h"
#include "../utils/utils.h"
int
part_length(t_stack **stack, int part)
{
int i;
t_stack *ptr;
i = 0;
ptr = *stack;
while (ptr && ptr->part != part)
ptr = ptr->next;
while (ptr && ptr->part == part)
{
i++;
ptr = ptr->next;
}
return (i);
}
int
count_parts(t_stack **stack)
{
int i;
int tmp;
t_stack *ptr;
i = 0;
tmp = -1;
ptr = *stack;
while (ptr)
{
if (ptr->part != tmp)
{
i++;
tmp = ptr->part;
}
ptr = ptr->next;
}
return (1);
}
void
print_val(char *str, int val)
{
ft_puterror(str);
ft_putnbr_fd(val, 2);
ft_puterror("\n");
}
int
new_part(t_stack **a_stack, t_stack **b_stack)
{
int tmp;
t_stack *ptr;
tmp = -1;
ptr = *a_stack;
while (ptr)
{
if (tmp < ptr->part)
tmp = ptr->part;
ptr = ptr->next;
}
ptr = *b_stack;
while (ptr)
{
if (tmp < ptr->part)
tmp = ptr->part;
ptr = ptr->next;
}
return (tmp + 1);
}
int
smallest(t_stack **stack)
{
t_stack *ptr;
int val;
ptr = *stack;
val = ptr->value;
ptr = ptr->next;
while (ptr)
{
if (ptr->value < val)
val = ptr->value;
ptr = ptr->next;
}
return (val);
}

93
srcs/push_swap/error.c Normal file
View File

@@ -0,0 +1,93 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* error.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <lejulien@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/05 15:59:25 by lejulien #+# #+# */
/* Updated: 2021/04/01 14:51:10 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include <stdlib.h>
#include "push_swap.h"
#include "../utils/utils.h"
#include <unistd.h>
void
ft_free_stack(t_stack **stack)
{
t_stack *tmp;
t_stack *nxt;
if (!*stack)
return ;
tmp = *stack;
while (tmp != NULL)
{
nxt = tmp->next;
free(tmp);
tmp = nxt;
}
*stack = NULL;
}
int
ft_free_stacks(t_stack **a_stack, t_stack **b_stack, int ret)
{
ft_free_stack(a_stack);
if (b_stack != NULL)
ft_free_stack(b_stack);
return (ret);
}
int
has_double(t_stack **stack)
{
t_stack *ptr1;
t_stack *ptr2;
ptr1 = *stack;
ptr2 = ptr1->next;
while (ptr1->next != NULL)
{
ptr2 = ptr1->next;
while (ptr2 != NULL)
{
if (ptr1->value == ptr2->value)
return (1);
ptr2 = ptr2->next;
}
ptr1 = ptr1->next;
}
return (0);
}
void
ft_puterror(char *str)
{
int i;
i = 0;
while (str[i] != '\0')
{
write(2, &str[i], 1);
i++;
}
}
int
is_part_in_stack(t_stack **stack, int part)
{
t_stack *ptr;
ptr = *stack;
while (ptr)
{
if (ptr->part == part)
return (1);
ptr = ptr->next;
}
return (0);
}

61
srcs/push_swap/goto.c Normal file
View File

@@ -0,0 +1,61 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* goto.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/04/01 17:34:57 by lejulien #+# #+# */
/* Updated: 2021/04/04 17:54:41 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "push_swap.h"
#include "../utils/utils.h"
static void
ft_goto_rotate(t_stack **stack, int pos, char *name)
{
while (pos != 0)
{
rotate(stack);
ft_putstr("r");
ft_putstr(name);
ft_putstr("\n");
pos--;
}
}
static void
ft_goto_r_rotate(t_stack **stack, int pos, char *name)
{
while (pos != stack_len(stack))
{
r_rotate(stack);
ft_putstr("rr");
ft_putstr(name);
ft_putstr("\n");
pos++;
}
}
void
ft_goto(t_stack **stack, int val, char *name)
{
t_stack *ptr;
int pos;
pos = 0;
ptr = *stack;
while (ptr && ptr->value != val)
{
ptr = ptr->next;
pos++;
}
if (pos == 0)
return ;
if (pos <= (int)(stack_len(stack) / 2))
ft_goto_rotate(stack, pos, name);
else
ft_goto_r_rotate(stack, pos, name);
}

97
srcs/push_swap/last_max.c Normal file
View File

@@ -0,0 +1,97 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* last_max.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/04/01 17:41:48 by lejulien #+# #+# */
/* Updated: 2021/04/01 17:42:37 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "push_swap.h"
#include "../utils/utils.h"
#include <stdio.h>
int
is_val_in_part(t_stack **stack, int val, int part)
{
t_stack *ptr;
ptr = *stack;
while (ptr && ptr->part != part)
ptr = ptr->next;
while (ptr && ptr->part == part)
{
if (ptr->value == val)
return (1);
ptr = ptr->next;
}
return (0);
}
static int
get_max(t_stack **b_stack)
{
t_stack *ptr;
int max;
if (!*b_stack)
return (-1);
ptr = *b_stack;
max = ptr->value;
ptr = ptr->next;
while (ptr)
{
if (ptr->value > max)
max = ptr->value;
ptr = ptr->next;
}
return (max);
}
void
go_max(t_stack **b_stack, int part)
{
t_stack *ptr;
ptr = *b_stack;
if (!*b_stack)
return ;
ft_putnbr_fd(get_max(b_stack), 2);
return ;
while (ptr->value != get_max(b_stack))
{
rotate(b_stack);
ft_putstr("rb\n");
ptr = *b_stack;
}
}
int
get_last_val(t_stack **stack)
{
t_stack *ptr;
ptr = *stack;
while (ptr->next != NULL)
ptr = ptr->next;
return (ptr->value);
}
int
stack_len(t_stack **stack)
{
t_stack *ptr;
int i;
i = 0;
ptr = *stack;
while (ptr)
{
ptr = ptr->next;
i++;
}
return (i);
}

108
srcs/push_swap/push_swap.c Normal file
View File

@@ -0,0 +1,108 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* push_swap.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <lejulien@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/05 13:01:57 by lejulien #+# #+# */
/* Updated: 2021/04/01 16:47:37 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "../utils/utils.h"
#include <unistd.h>
#include "push_swap.h"
#include <stdlib.h>
static int
push_values_to_stack(t_stack **stack, char **av, int ac, int pos)
{
int i;
t_stack *b_stack;
t_stack *ptr;
b_stack = NULL;
i = pos;
while (i < ac)
{
if (add_to_stack(stack, ft_atoi(av[i]), pos))
return (ft_free_stacks(stack, &b_stack, 1));
i++;
}
ptr = *stack;
if (has_double(stack))
return (ft_free_stacks(stack, &b_stack, 1));
sort(stack, &b_stack);
write(1, "\x4", 1);
return (ft_free_stacks(stack, &b_stack, 1) - 1);
}
static int
is_flag(char *str)
{
if (str[0] == '-' && str[1] == 'v')
return (1);
return (0);
}
int
is_number(char *c)
{
int i;
i = 0;
while (c[i] != '\0')
{
if (c[i] < '0' || c[i] > '9')
return (0);
i++;
}
return (1);
}
static int
check_flags(int ac, char **av)
{
int i;
int x;
i = 0;
if (ac > 2)
{
if (is_flag(av[1]))
i++;
}
x = 1 + i;
while (x < ac)
{
if (!is_number(av[x]))
return (0);
x++;
}
return (1 + i);
}
int
main(int ac, char **av)
{
t_stack *a_stack;
int flags;
a_stack = NULL;
flags = 1;
if (ac > 1)
{
if (check_num(ac, av) || check_max(ac, av))
{
ft_putstr("Error\n");
return (1);
}
if (push_values_to_stack(&a_stack, av, ac, flags))
{
ft_putstr("Error\n");
return (1);
}
}
return (0);
}

View File

@@ -0,0 +1,66 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* push_swap.h :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <lejulien@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/11 14:24:17 by lejulien #+# #+# */
/* Updated: 2021/04/01 18:20:53 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#ifndef PUSH_SWAP_H
# define PUSH_SWAP_H
typedef struct s_stack
{
int value;
int disp;
int part;
struct s_stack *next;
} t_stack;
int add_to_stack(t_stack **stack, int value, int pos);
int ft_free_stacks(t_stack **a_stack, t_stack **b_stack,
int ret);
void display_stack(t_stack **a_stack, t_stack **b_stack);
int has_double(t_stack **stack);
int entry(t_stack **a_stack, t_stack **b_stack);
void push(t_stack **a_stack, t_stack **b_stack);
void swap(t_stack **stack);
void rotate(t_stack **stack);
void r_rotate(t_stack **stack);
int check_stack(t_stack **stack);
void bubble_sort(t_stack **stack, int nbr);
int part_length(t_stack **stack, int part);
void quick_sort(t_stack **a_stack, t_stack **b_stack);
int count_parts(t_stack **stack);
void ft_puterror(char *str);
int new_part(t_stack **a_stack, t_stack **b_stack);
void debug_stack(t_stack **stack, char *str);
int is_part_in_stack(t_stack **stack, int part);
int r_check_stack(t_stack **stack);
void sort(t_stack **a_stack, t_stack **b_stack);
int smallest(t_stack **stack);
int biggest(t_stack **stack);
void move_top(int val, t_stack **stack);
void print_val(char *str, int val);
int val_pos(int val, t_stack **stack);
int is_val_in_part(t_stack **stack, int val, int part);
void stack_dup(t_stack **res, t_stack **src);
void ft_free_stack(t_stack **stack);
void chunked(t_stack **stack, int nbr);
void sort_chunck(t_stack **a_stack, t_stack **b_stack,
t_stack **test_stack, int nbr);
void go_max(t_stack**b_stack, int part);
int get_last_val(t_stack **stack);
void ft_goto(t_stack **stack, int val, char *name);
int stack_len(t_stack **stack);
int check_max(int ac, char **av);
int check_num(int ac, char **av);
void pa(t_stack **a_stack, t_stack **b_stack);
void ra(t_stack **a_stack);
void place_val(int val, t_stack **b_stack, t_stack **a_stack,
int part);
#endif

View File

@@ -0,0 +1,63 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* push_swap2.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/04/01 15:03:15 by lejulien #+# #+# */
/* Updated: 2021/04/02 13:31:16 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "../utils/utils.h"
#include <stdlib.h>
int
check_num(int ac, char **av)
{
int i;
int j;
i = 1;
while (i < ac)
{
j = 0;
while (av[i][j] != '\0')
{
if (av[i][j] < '0' || av[i][j] > '9')
{
if (av[i][j] != '-')
return (1);
}
j++;
}
i++;
}
return (0);
}
int
check_max(int ac, char **av)
{
int i;
char *tmp;
int i_tmp;
i = 1;
while (i < ac)
{
if (av[i][0] == '\0')
return (1);
i_tmp = ft_atoi(av[i]);
tmp = ft_itoa(i_tmp);
if (i_tmp != 0 && my_strcmp(av[i], tmp))
{
free(tmp);
return (1);
}
free(tmp);
i++;
}
return (0);
}

128
srcs/push_swap/sort.c Normal file
View File

@@ -0,0 +1,128 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* sort.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <lejulien@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/23 13:32:28 by lejulien #+# #+# */
/* Updated: 2021/04/04 18:06:18 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "push_swap.h"
#include "../utils/utils.h"
#include <stdlib.h>
static void
sort_3_two(t_stack **a_stack, t_stack *ptr)
{
if (ptr->next->value < ptr->next->next->value &&
ptr->next->next->value < ptr->value)
{
rotate(a_stack);
ft_putstr("ra\n");
}
else if (ptr->value < ptr->next->next->value &&
ptr->next->next->value < ptr->next->value)
{
swap(a_stack);
ft_putstr("sa\n");
rotate(a_stack);
ft_putstr("ra\n");
}
else if (ptr->next->next->value < ptr->value &&
ptr->value < ptr->next->value)
{
r_rotate(a_stack);
ft_putstr("rra\n");
}
}
static void
sort_3(t_stack **a_stack)
{
t_stack *ptr;
ptr = *a_stack;
if (ptr->next->value < ptr->value && ptr->value < ptr->next->next->value)
{
swap(a_stack);
ft_putstr("sa\n");
}
else if (ptr->value > ptr->next->value &&
ptr->next->value > ptr->next->next->value)
{
swap(a_stack);
ft_putstr("sa\n");
r_rotate(a_stack);
ft_putstr("rra\n");
}
else
sort_3_two(a_stack, ptr);
}
static int
greater_than(int val, t_stack **stack)
{
t_stack *ptr;
ptr = *stack;
while (ptr->value != smallest(stack))
ptr = ptr->next;
while (ptr->value < val)
{
ptr = ptr->next;
if (!ptr)
ptr = *stack;
}
return (ptr->value);
}
static void
sort_5(t_stack **a_stack, t_stack **b_stack)
{
t_stack *ptr;
while (stack_len(a_stack) != 3)
{
ft_goto(a_stack, smallest(a_stack), "a");
push(a_stack, b_stack);
ft_putstr("pb\n");
}
sort_3(a_stack);
ft_goto(a_stack, smallest(a_stack), "a");
while (*b_stack)
{
push(b_stack, a_stack);
ft_putstr("pa\n");
}
}
void
sort(t_stack **a_stack, t_stack **b_stack)
{
t_stack *test_stack;
int parts;
if (check_stack(a_stack) == 0 || stack_len(a_stack) == 1)
return ;
parts = (int)((ft_sqrt(part_length(a_stack, 0))) / 2.0);
if (part_length(a_stack, 0) > 3 && part_length(a_stack, 0) < 51)
sort_3(a_stack);
else if (part_length(a_stack, 0) == 5)
sort_5(a_stack, b_stack);
else if (part_length(a_stack, 0) == 2)
{
swap(a_stack);
ft_putstr("sa\n");
}
else
{
stack_dup(&test_stack, a_stack);
bubble_sort(&test_stack, part_length(&test_stack, 0));
chunked(&test_stack, parts);
sort_chunck(a_stack, b_stack, &test_stack, parts);
ft_free_stack(&test_stack);
}
}

111
srcs/push_swap/sort_chunk.c Normal file
View File

@@ -0,0 +1,111 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* sort_chunk.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/04/01 18:02:43 by lejulien #+# #+# */
/* Updated: 2021/04/01 18:03:58 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include "push_swap.h"
#include "../utils/utils.h"
static void
put_prev_chunk_down(t_stack **a_stack, t_stack **test_stack, int part)
{
t_stack *ptr;
int last;
ptr = *a_stack;
if (part == 1)
return ;
while (ptr && ptr->part != part - 1)
ptr = ptr->next;
while (ptr && ptr->part == part - 1)
ptr = ptr->next;
if (ptr)
ft_goto(a_stack, ptr->value, "a");
else
{
ptr = *a_stack;
ft_goto(a_stack, ptr->value, "a");
}
}
void
pa(t_stack **a_stack, t_stack **b_stack)
{
push(b_stack, a_stack);
ft_putstr("pa\n");
}
void
ra(t_stack **a_stack)
{
rotate(a_stack);
ft_putstr("ra\n");
}
static void
put_in_last(t_stack **a_stack, t_stack **b_stack, t_stack **test_stack,
int part)
{
int i;
int len;
t_stack *ptr;
t_stack *a_ptr;
ptr = *b_stack;
if (!ptr)
return ;
len = part_length(b_stack, part);
i = 0;
if (len != part_length(test_stack, part))
return ;
a_ptr = *a_stack;
put_prev_chunk_down(a_stack, test_stack, part);
while (i < len)
{
pa(a_stack, b_stack);
i++;
}
i = 0;
while (i < len)
{
ra(a_stack);
i++;
}
}
void
sort_chunck(t_stack **a_stack, t_stack **b_stack, t_stack **test_stack,
int nbr)
{
t_stack *a_ptr;
int i;
int j;
i = 0;
while (i < nbr)
{
j = 0;
while (j < part_length(test_stack, i + 1))
{
a_ptr = *a_stack;
while (is_val_in_part(test_stack, a_ptr->value, i + 1) == 0)
{
ra(a_stack);
a_ptr = *a_stack;
}
a_ptr->part = i + 1;
place_val(a_ptr->value, b_stack, a_stack, i + 1);
j++;
}
ft_goto(b_stack, biggest(b_stack), "b");
put_in_last(a_stack, b_stack, test_stack, i + 1);
i++;
}
}

46
srcs/utils/ft_atoi.c Normal file
View File

@@ -0,0 +1,46 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_atoi.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <lejulien@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/05 13:06:04 by lejulien #+# #+# */
/* Updated: 2021/04/01 13:38:37 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
static int ft_isspace(char c)
{
if ((c == '\f') || (c == '\t') || (c == '\n') || (c == '\r')
|| (c == '\v') || (c == ' '))
{
return (1);
}
return (0);
}
int ft_atoi(const char *str)
{
int nbr;
int sign;
int index;
nbr = 0;
sign = 1;
index = 0;
while ((ft_isspace(str[index]) == 1) && str[index] != '\0')
index++;
if ((str[index] == '+') || (str[index] == '-'))
{
if (str[index] == '-')
sign = -1;
index++;
}
while ((str[index] >= '0') && (str[index] <= '9'))
{
nbr = (nbr * 10) + (str[index] - '0');
index++;
}
return (sign * nbr);
}

62
srcs/utils/ft_itoa.c Normal file
View File

@@ -0,0 +1,62 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_itoa.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/31 16:22:36 by lejulien #+# #+# */
/* Updated: 2021/03/31 16:22:41 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include <stdlib.h>
static char *ft_itoa2(int iszero, unsigned int nu, int i)
{
char *res;
if (!(res = malloc((i + 1) * sizeof(char))))
return (0);
res[i] = '\0';
while (nu > 0)
{
i--;
res[i] = nu % 10 + '0';
nu = nu / 10;
}
i--;
if (iszero)
{
res[i] = nu + '0';
i--;
}
if (i == 0)
res[i] = '-';
return (res);
}
char *ft_itoa(int n)
{
unsigned int nu;
int i;
int iszero;
i = 0;
if (n <= 0)
{
nu = -n;
i++;
}
else
nu = n;
iszero = 0;
while (n != 0)
{
n = n / 10;
i++;
}
if (nu == 0)
iszero++;
return (ft_itoa2(iszero, nu, i));
}

38
srcs/utils/ft_putnbr_fd.c Normal file
View File

@@ -0,0 +1,38 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_putnbr_fd.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <lejulien@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/05 13:05:29 by lejulien #+# #+# */
/* Updated: 2021/03/05 13:05:39 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include <unistd.h>
static void ft_putchar(char c, int fd)
{
write(fd, &c, 1);
}
void ft_putnbr_fd(int nb, int fd)
{
unsigned int dnb;
if (nb < 0)
{
ft_putchar('-', fd);
dnb = nb * (-1);
}
else
dnb = nb;
if (dnb >= 10)
{
ft_putnbr_fd(dnb / 10, fd);
ft_putchar(dnb % 10 + '0', fd);
}
else
ft_putchar(dnb + '0', fd);
}

26
srcs/utils/ft_putstr.c Normal file
View File

@@ -0,0 +1,26 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_putstr.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <lejulien@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/05 13:08:09 by lejulien #+# #+# */
/* Updated: 2021/03/05 13:09:54 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#include <unistd.h>
void
ft_putstr(const char *str)
{
int i;
i = 0;
while (str[i] != '\0')
{
write(1, &str[i], 1);
i++;
}
}

28
srcs/utils/ft_sqrt.c Normal file
View File

@@ -0,0 +1,28 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_sqrt.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2019/08/12 13:38:59 by lejulien #+# #+# */
/* Updated: 2021/03/29 17:40:39 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
float ft_sqrt(float n)
{
float x;
float y;
float e;
x = n;
y = 1;
e = 0.00001;
while (x - y > e)
{
x = (x + y) / 2;
y = n / x;
}
return (x);
}

28
srcs/utils/ft_strcmp.c Normal file
View File

@@ -0,0 +1,28 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_strcmp.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/31 15:46:04 by lejulien #+# #+# */
/* Updated: 2021/04/01 13:38:20 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
int my_strcmp(char *s1, char *s2)
{
int index;
index = 0;
while (s2[index] && s1[index])
{
if (s1[index] == s2[index])
index++;
else
return (1);
}
if (s1[index] == '\0' && s2[index] == '\0')
return (0);
return (1);
}

22
srcs/utils/utils.h Normal file
View File

@@ -0,0 +1,22 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* utils.h :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lejulien <lejulien@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/05 13:06:31 by lejulien #+# #+# */
/* Updated: 2021/03/31 16:01:35 by lejulien ### ########.fr */
/* */
/* ************************************************************************** */
#ifndef UTILS_H
# define UTILS_H
int ft_atoi(const char *str);
char *ft_itoa(int n);
void ft_putnbr_fd(int nb, int fd);
void ft_putstr(const char *str);
float ft_sqrt(float nb);
int my_strcmp(char *s1, char *s2);
#endif

124
test.sh Executable file
View File

@@ -0,0 +1,124 @@
#!/bin/bash
make re
printf "### CHECKER TEST ###\n" # checker
printf "1 non-numeric case\n"
export ARG="a"
./checker $ARG
printf "\n\n"
printf "3 non-numeric case\n"
export ARG="a b c"
./checker $ARG
printf "\n\n"
printf "dup case\n"
export ARG="1 1"
./checker $ARG
printf "\n\n"
printf "I_max case\n"
export ARG="1 2147483649"
./checker $ARG
printf "\n\n"
printf "no arg case\n"
./checker
printf "\n\n"
printf "non existing instructions case\n"
export ARG="14 7 9"
printf "patate\n" | ./checker $ARG
printf "\n\n"
printf "space before instructions case\n"
export ARG="14 7 9"
printf " pb\n" | ./checker $ARG
printf "\n\n"
printf "space after instructions case\n"
export ARG="14 7 9"
printf "pb \n" | ./checker $ARG
printf "\n\n"
printf "manual entry case (please enter some instruction then ctrl-D)\n"
export ARG="14 7 9"
./checker $ARG
printf "\n\n"
printf "manual entry case (please enter some instruction then ctrl-D)\n"
export ARG="0 1 2 3"
./checker $ARG
printf "\n\n"
printf "### PUSH_SWAP TEST ###\n" # push_swap test
printf "one case\n"
export ARG="42"
./push_swap $ARG
printf "\n\n"
printf "ordered case\n"
export ARG="0 1 2 3 4"
./push_swap $ARG
printf "\n\n"
printf "longer ordered case\n"
export ARG="0 1 2 3 4 5 6 7 8 9"
./push_swap $ARG
printf "\n\n"
printf "### PUSH_SWAP AND CHECKER TEST ###\n" # push_swap and checker test
printf "one case\n"
export ARG="200"
./push_swap $ARG | ./checker $ARG
printf "len-->"
./push_swap $ARG | grep -c ""
printf "\n\n"
printf "two case\n"
export ARG="500 200"
./push_swap $ARG | ./checker $ARG
printf "len-->"
./push_swap $ARG | grep -c ""
printf "\n\n"
printf "three case\n"
export ARG="200 0 500"
./push_swap $ARG | ./checker $ARG
printf "len-->"
./push_swap $ARG | grep -c ""
printf "\n\n"
printf "five case\n"
export ARG="200 0 88 -42 100"
./push_swap $ARG | ./checker $ARG
printf "len-->"
./push_swap $ARG | grep -c ""
printf "\n\n"
printf "one hundred case\n"
export ARG=`ruby -e "puts (1...100).to_a.shuffle.join(' ')"`
./push_swap $ARG | ./checker $ARG
printf "len-->"
./push_swap $ARG | grep -c ""
printf "\n\n"
printf "five hundred case\n"
export ARG=`ruby -e "puts (1...500).to_a.shuffle.join(' ')"`
./push_swap $ARG | ./checker $ARG
printf "len-->"
./push_swap $ARG | grep -c ""
printf "\n\n"
printf "all-ready solve case\n"
export ARG="0 1 2 3 4 5 6 7 8"
./push_swap $ARG | ./checker $ARG
printf "len-->"
./push_swap $ARG | grep -c ""
printf "\n\n"
make fclean