-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpush_swap_lists_bonus.c
87 lines (77 loc) · 1.94 KB
/
push_swap_lists_bonus.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* push_swap_lists_bonus.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: masoares <masoares@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/11/12 11:41:31 by masoares #+# #+# */
/* Updated: 2023/11/29 15:07:53 by masoares ### ########.fr */
/* */
/* ************************************************************************** */
#include "push_swap_bonus.h"
t_stack *ft_lstnew_ps_bonus(int num)
{
t_stack *stack;
stack = (t_stack *) malloc (sizeof(t_stack));
if (stack == NULL)
return (NULL);
stack->num = num;
stack->index = 0;
stack->targ = NULL;
stack->m_cost = 0;
stack->ab_med = false;
stack->next = NULL;
stack->prev = NULL;
return (stack);
}
void ft_lstadd_back_ps_bonus(t_stack **lst, t_stack **new)
{
t_stack *temp;
temp = *lst;
if (*lst == NULL)
{
*lst = *new;
}
else
{
while (temp->next != NULL)
temp = temp->next;
temp->next = *new;
(*new)->prev = temp;
}
}
void ft_lstclear_ps_bonus(t_stack **lst)
{
t_stack *current;
t_stack *trav;
current = *lst;
while (current != NULL)
{
trav = current->next;
free(current);
current = trav;
}
*lst = NULL;
}
t_stack *ft_lstlast_ps_bonus(t_stack *lst)
{
if (lst == NULL)
return (NULL);
while (lst->next != NULL)
lst = lst->next;
return (lst);
}
int ft_lstsize_ps_bonus(t_stack *lst)
{
int count;
t_stack *trav;
count = 0;
trav = lst;
while (trav != NULL)
{
count++;
trav = trav->next;
}
return (count);
}