Nearly there !!!
WIP merge sort still problems with negative numbers
This commit is contained in:
parent
ac9b03acff
commit
428525b561
7
Makefile
7
Makefile
@ -6,7 +6,7 @@
|
|||||||
# By: tmaze <tmaze@student.42.fr> +#+ +:+ +#+ #
|
# By: tmaze <tmaze@student.42.fr> +#+ +:+ +#+ #
|
||||||
# +#+#+#+#+#+ +#+ #
|
# +#+#+#+#+#+ +#+ #
|
||||||
# Created: 2019/02/23 14:30:57 by tmaze #+# #+# #
|
# Created: 2019/02/23 14:30:57 by tmaze #+# #+# #
|
||||||
# Updated: 2019/02/25 15:55:49 by tmaze ### ########.fr #
|
# Updated: 2019/03/06 11:37:28 by tmaze ### ########.fr #
|
||||||
# #
|
# #
|
||||||
#******************************************************************************#
|
#******************************************************************************#
|
||||||
|
|
||||||
@ -42,10 +42,7 @@ SRC = ps_push.c \
|
|||||||
ps_rerot.c \
|
ps_rerot.c \
|
||||||
ps_swap.c \
|
ps_swap.c \
|
||||||
ps_stktools.c \
|
ps_stktools.c \
|
||||||
ps_stktools2.c \
|
ps_stktools2.c
|
||||||
ft_strsplitwhitespace.c\
|
|
||||||
\
|
|
||||||
checker.c
|
|
||||||
|
|
||||||
MAIN1 = checker.c
|
MAIN1 = checker.c
|
||||||
MAIN2 = push_swap.c
|
MAIN2 = push_swap.c
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
/* By: tmaze <tmaze@student.42.fr> +#+ +:+ +#+ */
|
/* By: tmaze <tmaze@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2019/02/21 14:13:53 by tmaze #+# #+# */
|
/* Created: 2019/02/21 14:13:53 by tmaze #+# #+# */
|
||||||
/* Updated: 2019/03/02 18:21:11 by tmaze ### ########.fr */
|
/* Updated: 2019/03/06 11:07:38 by tmaze ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -22,6 +22,7 @@
|
|||||||
typedef struct s_stack
|
typedef struct s_stack
|
||||||
{
|
{
|
||||||
int nb;
|
int nb;
|
||||||
|
int ind;
|
||||||
struct s_stack *next;
|
struct s_stack *next;
|
||||||
} t_stack;
|
} t_stack;
|
||||||
|
|
||||||
@ -45,7 +46,7 @@ void ps_initdata(t_psdata *data);
|
|||||||
|
|
||||||
void ps_swap(t_psdata *data, char c);
|
void ps_swap(t_psdata *data, char c);
|
||||||
void ps_sswap(t_psdata *data);
|
void ps_sswap(t_psdata *data);
|
||||||
void ps_push(t_psdata *data, char c);
|
int ps_push(t_psdata *data, char c);
|
||||||
void ps_rot(t_psdata *data, char c);
|
void ps_rot(t_psdata *data, char c);
|
||||||
void ps_rrot(t_psdata *data);
|
void ps_rrot(t_psdata *data);
|
||||||
void ps_rerot(t_psdata *data, char c);
|
void ps_rerot(t_psdata *data, char c);
|
||||||
|
@ -6,16 +6,17 @@
|
|||||||
/* By: tmaze <tmaze@student.42.fr> +#+ +:+ +#+ */
|
/* By: tmaze <tmaze@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2019/02/21 15:59:46 by tmaze #+# #+# */
|
/* Created: 2019/02/21 15:59:46 by tmaze #+# #+# */
|
||||||
/* Updated: 2019/02/23 15:45:30 by tmaze ### ########.fr */
|
/* Updated: 2019/03/06 11:36:38 by tmaze ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "push_swap.h"
|
#include "push_swap.h"
|
||||||
|
|
||||||
void ps_push(t_psdata *data, char c)
|
int ps_push(t_psdata *data, char c)
|
||||||
{
|
{
|
||||||
t_stack *tmp;
|
t_stack *tmp;
|
||||||
|
|
||||||
tmp = ps_stkpop(data, (c == 'a') ? c : 'b');
|
if ((tmp = ps_stkpop(data, (c == 'a') ? 'b' : 'a')) != NULL)
|
||||||
ps_stkpsh(data, c, tmp);
|
ps_stkpsh(data, c, tmp);
|
||||||
|
return (tmp != NULL);
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
/* By: tmaze <tmaze@student.42.fr> +#+ +:+ +#+ */
|
/* By: tmaze <tmaze@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2019/02/22 14:41:27 by tmaze #+# #+# */
|
/* Created: 2019/02/22 14:41:27 by tmaze #+# #+# */
|
||||||
/* Updated: 2019/03/02 15:23:43 by tmaze ### ########.fr */
|
/* Updated: 2019/03/06 11:37:06 by tmaze ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -61,12 +61,10 @@ t_stack *ps_stkpop(t_psdata *data, char c)
|
|||||||
s = &(data->a);
|
s = &(data->a);
|
||||||
if (c == 'a')
|
if (c == 'a')
|
||||||
size = &(data->size_a);
|
size = &(data->size_a);
|
||||||
if (c == 'b')
|
else if (c == 'b')
|
||||||
s = &(data->b);
|
s = &(data->b);
|
||||||
if (c == 'b')
|
if (c == 'b')
|
||||||
size = &(data->size_b);
|
size = &(data->size_b);
|
||||||
else if (c != 'a' && c != 'b')
|
|
||||||
return (NULL);
|
|
||||||
ret = NULL;
|
ret = NULL;
|
||||||
if (s != NULL && *s != NULL)
|
if (s != NULL && *s != NULL)
|
||||||
{
|
{
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
/* By: tmaze <tmaze@student.42.fr> +#+ +:+ +#+ */
|
/* By: tmaze <tmaze@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2019/02/21 14:06:40 by tmaze #+# #+# */
|
/* Created: 2019/02/21 14:06:40 by tmaze #+# #+# */
|
||||||
/* Updated: 2019/03/02 15:34:54 by tmaze ### ########.fr */
|
/* Updated: 2019/03/06 12:02:03 by tmaze ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -14,23 +14,24 @@
|
|||||||
|
|
||||||
void ps_swap(t_psdata *data, char c)
|
void ps_swap(t_psdata *data, char c)
|
||||||
{
|
{
|
||||||
t_stack *s;
|
t_stack **s;
|
||||||
size_t size;
|
size_t size;
|
||||||
int tmp;
|
t_stack *tmp;
|
||||||
|
|
||||||
if (c == 'a')
|
if (c == 'a')
|
||||||
s = data->a;
|
s = &(data->a);
|
||||||
if (c == 'a')
|
if (c == 'a')
|
||||||
size = data->size_a;
|
size = data->size_a;
|
||||||
else if (c == 'b')
|
else if (c == 'b')
|
||||||
s = data->b;
|
s = &(data->b);
|
||||||
if (c == 'b')
|
if (c == 'b')
|
||||||
size = data->size_b;
|
size = data->size_b;
|
||||||
if (s != NULL && size >= 2)
|
if (s != NULL && size >= 2)
|
||||||
{
|
{
|
||||||
tmp = s->nb;
|
tmp = *s;
|
||||||
s->nb = s->next->nb;
|
*s = (*s)->next;
|
||||||
s->next->nb = tmp;
|
tmp->next = (*s)->next;
|
||||||
|
(*s)->next = tmp;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
104
srcs/push_swap.c
104
srcs/push_swap.c
@ -6,34 +6,114 @@
|
|||||||
/* By: tmaze <tmaze@student.42.fr> +#+ +:+ +#+ */
|
/* By: tmaze <tmaze@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2019/03/03 11:41:49 by tmaze #+# #+# */
|
/* Created: 2019/03/03 11:41:49 by tmaze #+# #+# */
|
||||||
/* Updated: 2019/03/05 18:19:58 by tmaze ### ########.fr */
|
/* Updated: 2019/03/06 12:10:10 by tmaze ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "push_swap.h"
|
#include "push_swap.h"
|
||||||
|
|
||||||
void sort(t_psdata *data, int sortby)
|
int sort(t_psdata *data, int size)
|
||||||
{
|
{
|
||||||
|
t_stack *ptr;
|
||||||
int i;
|
int i;
|
||||||
int j;
|
|
||||||
|
|
||||||
if (sortby => 2)
|
|
||||||
sort(data, sortby / 2);
|
|
||||||
i = data->size_a / sortby;
|
|
||||||
j = sortby;
|
|
||||||
|
|
||||||
|
printf("start sort %d\n", size);
|
||||||
|
if (size > 2)
|
||||||
|
{
|
||||||
|
if (!sort(data, ((size % 2) ? size + 1 : size) / 2))
|
||||||
|
return (0);
|
||||||
|
if (!sort(data, size - (((size % 2) ? size + 1 : size) / 2)))
|
||||||
|
return (0);
|
||||||
|
}
|
||||||
|
else if (size == 1)
|
||||||
|
return (1);
|
||||||
|
i = 0;
|
||||||
|
ptr = data->a;
|
||||||
|
while (i < ((size % 2) ? size + 1 : size) / 2)
|
||||||
|
{
|
||||||
|
ptr->ind = 1;
|
||||||
|
ptr = ptr->next;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
i = 0;
|
||||||
|
while (ptr && i < (size - (((size % 2) ? size + 1 : size) / 2)))
|
||||||
|
{
|
||||||
|
ptr->ind = 2;
|
||||||
|
ptr = ptr->next;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
i = 0;
|
||||||
|
ptr = data->a;
|
||||||
|
while (ptr)
|
||||||
|
{
|
||||||
|
printf("@ind %d: nb=%d ind=%d\n", i, ptr->nb, ptr->ind);
|
||||||
|
ptr = ptr->next;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
while (data->a->ind == 1)
|
||||||
|
{
|
||||||
|
printf("pb\n");
|
||||||
|
if (!ps_push(data, 'b'))
|
||||||
|
return (0);
|
||||||
|
if (data->size_b > 1)
|
||||||
|
{
|
||||||
|
printf("rb\n");
|
||||||
|
ps_rot(data, 'b');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (data->a->ind != 0 || data->size_b > 0)
|
||||||
|
{
|
||||||
|
printf("data->a->ind %d\ndata->a->nb %d\ndata->size_b %zu\n", data->a->ind, data->a->nb, data->size_b);
|
||||||
|
if ((data->a->ind != 0 && data->size_b > 0 && data->a->nb > data->b->nb)
|
||||||
|
|| (data->a->ind == 0 && data->size_b > 0))
|
||||||
|
{
|
||||||
|
printf("pa\n");
|
||||||
|
ps_push(data, 'a');
|
||||||
|
}
|
||||||
|
printf("mise a zero:\ndata->a->ind %d\ndata->a->nb %d\n", data->a->ind, data->a->nb);
|
||||||
|
data->a->ind = 0;
|
||||||
|
printf("ra\n");
|
||||||
|
ps_rot(data, 'a');
|
||||||
|
i = 0;
|
||||||
|
ptr = data->a;
|
||||||
|
while (ptr)
|
||||||
|
{
|
||||||
|
printf("@ind %d: nb=%d ind=%d\n", i, ptr->nb, ptr->ind);
|
||||||
|
ptr = ptr->next;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(int ac, char **av)
|
int main(int ac, char **av)
|
||||||
{
|
{
|
||||||
|
t_stack *ptr;
|
||||||
t_psdata data;
|
t_psdata data;
|
||||||
|
|
||||||
ps_initdata(&data);
|
ps_initdata(&data);
|
||||||
ret = 0;
|
|
||||||
if (!get_params(&data, ac, av))
|
if (!get_params(&data, ac, av))
|
||||||
return (0);
|
return (0);
|
||||||
new = data.a;
|
ptr = data.a;
|
||||||
if (new == NULL)
|
if (ptr == NULL)
|
||||||
ft_putendl("Empty");
|
ft_putendl("Empty");
|
||||||
sort(&data, ((data.size_a % 2) ? data.sizea + 1 : data.size_a) / 2);
|
while (ptr)
|
||||||
|
{
|
||||||
|
ptr->ind = 0;
|
||||||
|
ptr = ptr->next;
|
||||||
|
}
|
||||||
|
if (!sort(&data, data.size_a))
|
||||||
|
{
|
||||||
|
printf("Error\n");
|
||||||
|
ps_stkclean(&data);
|
||||||
|
return (1);
|
||||||
|
}
|
||||||
|
ptr = data.a;
|
||||||
|
while (ptr)
|
||||||
|
{
|
||||||
|
printf("%d\n", ptr->nb);
|
||||||
|
ptr->ind = 0;
|
||||||
|
ptr = ptr->next;
|
||||||
|
}
|
||||||
|
return (0);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user