Sort multiple arrays given a permutation.
The simplest way to use this crate is the co_sort! macro, it will sort the first array and swap elements of the others in order to mimic the changes in the first array. \ Usefull when you have multiple slices with an implicit relation. ```rust
use cosort::*;
let mut names = ["Diego", "Maia", "Luciana", "Bruno", "Astrid", "Thierry"];
let mut ages = [ 73, 88, 21, 47, 4, 62 ];
// We want to sort the names but keep the ages synced
cosort![names, ages];
asserteq!(names, ["Astrid", "Bruno", "Diego", "Luciana", "Maia", "Thierry"]);
asserteq!(ages, [ 4, 47, 73, 21, 88, 62 ]);
If you want more control you can use the functions co_sort and co_sort_stable, the macro uses co_sort internally. \
co_sort_stable allocates O(n) memory and requires the types to implement Clone while co_sort is in place and doesn't require any trait. \
Performance wise co_sort scale well with the number of arrays but not with their size and co_sort_stable is the opposite.
rust
let mut names = ["Diego", "Maia", "Luciana", "Bruno", "Astrid", "Thierry"]; let mut ages = [ 73, 88, 21, 47, 4, 62 ]; let permutation = Permutation::from(names.asref()); permutation.cosort((names.asmut(), ages.asmut())); // or permutation.cosortstable((names.asmut(), ages.asmut())); asserteq!(names, ["Astrid", "Bruno", "Diego", "Luciana", "Maia", "Thierry"]); asserteq!(ages, [ 4, 47, 73, 21, 88, 62 ]); ```
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.