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

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++;
}
}