-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreverse_rotate.c
49 lines (44 loc) · 924 Bytes
/
reverse_rotate.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
#include "push_swap.h"
/**
* @brief Fait l'inverse de la fonction rotate.
*/
void reverse_rotate(t_stack **stack)
{
t_stack *first;
t_stack *last;
if (stacklen(*stack) <= 1)
ft_putendl_fd("Stack is empty or has only one element", 1);
last = last_node(*stack);
first = *stack;
*stack = first->p;
last->p = first;
first->p = NULL;
return ;
}
/**
* @brief Décale d’une position vers le bas tous les élements de la pile a.
* Le dernier élément devient le premier.
*/
void rra(t_stack **a)
{
reverse_rotate(a);
ft_putendl_fd("rra", 1);
}
/**
* @brief Décale d’une position vers le bas tous les élements de la pile b.
* Le dernier élément devient le premier.
*/
void rrb(t_stack **b)
{
reverse_rotate(b);
ft_putendl_fd("rrb", 1);
}
/**
* @brief rra et rrb en même temps.
*/
void rrr(t_stack **a, t_stack **b)
{
reverse_rotate(a);
reverse_rotate(b);
ft_putendl_fd("rrr", 1);
}