Files
SortStack/src/big_sort.c
T
HexPloR 4c83562ca9 ez
2024-06-24 00:05:59 +02:00

92 lines
2.7 KiB
C

/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* big_sort.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: yantoine <yantoine@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/03/15 21:04:05 by yantoine #+# #+# */
/* Updated: 2024/03/21 18:11:09 by yantoine ### ########.fr */
/* */
/* ************************************************************************** */
/*
#include "../includes/push_swap.h"
static int wich_algo(t_Liste *stack_a, t_Liste *stack_b)
{
if (stack_a->premier->number > stack_b->max)
return (1);
else if (stack_a->premier->number < stack_b->min)
return (2);
else
return (3);
}
static void exec_algo(t_Liste *stack_a, t_Liste *stack_b, int algo)
{
int i;
i = 0;
if (algo == 1)
push(stack_a, stack_b, 'b');
else if (algo == 2)
{
push(stack_a, stack_b, 'b');
rotate(stack_b, 'b');
}
else
{
if (stack_a->premier->number >= stack_b->moyenne)
{
while (stack_a->premier->number < stack_b->premier->number)
{
rotate(stack_b, 'b');
i++;
}
while (stack_a->premier->number >= stack_b->premier->number \
&& stack_a->premier->number <= stack_b->dernier->number)
push(stack_a, stack_b, 'b');
while (i > 0)
{
if (stack_a->premier->number > stack_b->premier->number \
&& stack_a->premier->number < stack_b->dernier->number)
push(stack_a, stack_b, 'b');
reverse_rotate(stack_b, 'b');
i--;
}
}
else
{
while (stack_a->premier->number < stack_b->premier->number \
|| stack_a->premier->number > stack_b->dernier->number)
{
reverse_rotate(stack_b, 'b');
i++;
}
while (stack_a->premier->number >= stack_b->premier->number \
&& stack_a->premier->number <= stack_b->dernier->number)
push(stack_a, stack_b, 'b');
while (i >= 0)
{
if (stack_a->premier->number < stack_b->premier->number \
&& stack_a->premier->number > stack_b->dernier->number)
push(stack_a, stack_b, 'b');
rotate(stack_b, 'b');
i--;
}
}
}
}
void big_sort(t_Liste *stack_a, t_Liste *stack_b)
{
int size;
size = stack_a->length;
while (stack_a->length > 1)
exec_algo(stack_a, stack_b, wich_algo(stack_a, stack_b));
while (stack_a->length != size)
push(stack_a, stack_b, 'a');
}
*/