fprintf(stderr, "\n");
}
-char *jacu_mtf(char *datos, int len)
+char *jacu_mtf(char *datos, int len, char **_z, int *z_len)
{
char *z;
- int *pos;
+ char *pos;
int i, size;
pos = (char *)malloc(len*sizeof(char));
z = jacu_buscar_z(datos, len, &size);
+ *_z = (char*)malloc(len*sizeof(char));
+ memcpy(*_z, z, len*sizeof(char));
for(i=0; i<len; i++){
pos[i] = get_pos(z, size, datos[i]);
if (pos[i] != 0)
- pop_front(z,pos[i]);
+ pop_front(z, pos[i]);
}
+ (*z_len) = size;
return pos;
}
-char *jacu_mtf_inv(char *z, int *pos, int len)
+char *jacu_mtf_inv(char *z, char *pos, int len)
{
char *datos;
int i;
datos = (char*)malloc(sizeof(char)*len);
for(i=0; i<len; i++){
- datos[i] = z[pos[i]];
- pop_front(z,pos[i]);
+ datos[i] = z[(size_t)pos[i]];
+ pop_front(z, pos[i]);
}
return datos;
}