]> git.llucax.com Git - z.facultad/75.06/jacu.git/blob - otros/blocksorting/bs.h
099acb2fccab9fed78f6a4d923eb261521c6d599
[z.facultad/75.06/jacu.git] / otros / blocksorting / bs.h
1
2 #ifndef _BS_H_
3 #define _BS_H_
4
5 #include <string.h>
6 #include <stdlib.h>
7 #include <stdio.h>
8
9 typedef struct _bs_t_ t_BlockSort;
10
11 typedef struct _bs_data_t_ {
12         unsigned long int pos_inicial;
13         unsigned long int pos_final;
14         unsigned long int pos_orden;
15         char ord; /* indica si esta ordenada */
16
17         /* Guardo el puntero al padre */
18         t_BlockSort *bs;        
19 } t_BlockSortData;
20
21 struct _bs_t_ {
22         char *data;
23         t_BlockSortData *array;
24         unsigned long int *ord;
25         unsigned long int len;
26 };
27
28 /** Inicializa un BlockSorting
29  *
30  *  \param len Tamaño de página a utilizar
31  */
32 t_BlockSort *bs_create(unsigned long int len);
33
34 /** Libera un BlockSorting
35  *
36  *  \param bs BlockSorting previamente inicializado.
37  */
38 void bs_destroy(t_BlockSort *bs);
39
40 /** Resuelve un BlockSorting
41  *
42  *  \param in Array de bytes que se pretende procesar.
43  *  \param out Array donde guardar la columna resultante.
44  *  \param k Puntero donde guardar la posicion del array original.
45  *  \oaram leido Tamaño de in (por si el tamaño de in es menor al de la pagina).
46  */
47 void bs_solve(char *in, char *out, t_BlockSort *bs, unsigned long int *k, unsigned int leido);
48
49 /** Obtiene el array original a partir de dst y k
50  *
51  *  \param dst Array donde guardar el array original
52  *  \param c Array generado opr bs_solve.
53  *  \param k Valor retornado por bs_solve.
54  *  \param len Tamaño de c
55  */
56 void bs_restore(char *dst, char *c, unsigned long int k, unsigned long int len);
57
58 #endif
59