I have an LDS instead of a LIS...

This commit is contained in:
Maix0 2024-01-12 19:42:25 +01:00
parent 3462169a6f
commit 54a5b658d4
4 changed files with 321 additions and 6 deletions

View file

@ -6,7 +6,7 @@
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/01/11 18:50:35 by maiboyer #+# #+# */
/* Updated: 2024/01/11 21:27:36 by maiboyer ### ########.fr */
/* Updated: 2024/01/12 19:41:23 by maiboyer ### ########.fr */
/* */
/* ************************************************************************** */
@ -164,7 +164,7 @@ t_i64 binary_search(t_vec_element *items, t_i64 i)
t_i64 mid;
lo = 0;
hi = items->len;
hi = items->len - 1;
while (lo < hi)
{
mid = lo + (hi - lo) / 2;
@ -227,5 +227,6 @@ t_vec_i64 lis(t_vec_element *elements)
result.buffer[u] = v;
v = previous_chain.buffer[v];
}
vec_i64_free(previous_chain);
return (result);
}

View file

@ -6,14 +6,13 @@
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/01/11 14:14:18 by maiboyer #+# #+# */
/* Updated: 2024/01/11 21:03:29 by maiboyer ### ########.fr */
/* Updated: 2024/01/12 19:28:15 by maiboyer ### ########.fr */
/* */
/* ************************************************************************** */
#include "app/dup_state.h"
#include "app/element.h"
#include "app/lis.h"
#include "app/moves.h"
#include "app/state.h"
#include "me/convert/atoi.h"
#include "me/convert/itoa.h"
@ -170,9 +169,9 @@ int main(t_i32 argc, t_str argv[])
state = parses_arguments(--argc, ++argv);
print_state(&state);
o = lis(&state.stack_a);
printf("len = %zu", o.len);
printf("len = %zu\n", o.len);
for (t_usize i = 0; i < o.len; i++)
printf("%zi\n", (t_isize)o.buffer[i]);
printf("%lli\n", state.stack_a.buffer[o.buffer[i]].value);
printf("\n");
free_state(state);
vec_i64_free(o);