-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathf_norm.c
102 lines (98 loc) · 2.14 KB
/
f_norm.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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* f_norm.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: jferrer- <jferrer-@student.42barc...> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2022/03/16 23:11:55 by jferrer- #+# #+# */
/* Updated: 2022/03/16 23:16:12 by jferrer- ### ########.fr */
/* */
/* ************************************************************************** */
#include "pushswap.h"
void norminette1(t_data *d, int i, int *bool, int temp)
{
while (d->ib[0] != i)
{
if (d->ib[0] == i - 1 && temp == 0)
{
bool[0] = 1;
pa(d);
}
if (d->ib[0] == (i - 2))
{
bool[1] = 1;
pa(d);
ra(d);
}
if (d->ib[0] != i)
rb(d);
}
}
void norminette2(t_data *d, int i, int *bool, int temp)
{
while (d->ib[0] != i)
{
if (d->ib[0] == i - 1 && temp == 0)
{
bool[0] = 1;
pa(d);
}
if (d->ib[0] == (i - 2))
{
bool[1] = 1;
pa(d);
ra(d);
}
if (d->ib[0] != i)
rrb(d);
}
}
int norminette3(t_data *d, int *bool)
{
if (bool[0] == 1 && bool[1] == 1)
{
sa(d);
rra(d);
return (3);
}
else if (bool[0] == 1 && bool[1] == 0)
{
sa(d);
return (1);
}
else if (bool[1] == 1 && bool[0] == 0)
{
if (d->sia > 2 && d->ia[0] > d->ia[1])
sa(d);
rra(d);
return (2);
}
return (0);
}
int norminette4(t_data *d, int count, int size, int part)
{
if (d->ia[0] < count * (size / part))
{
if (d->ia[0] >= (count * (size / part)) - (size / (2 * part)))
{
while (d->rbiq > 0)
{
d->rbiq--;
rb(d);
}
}
pb(d);
if (d->ib[0] < (count * (size / part)) - (size / (2 * part)))
d->rbiq++;
return (1);
}
else
{
if (d->rbiq > 0 && d->rbiq-- > 0)
rr(d);
else
ra(d);
}
return (0);
}