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
pub type DistanceMatrix = Vec<Vec<usize>>;
pub fn print_table(table: &DistanceMatrix) {
for row in table {
for item in row {
print!("{} ", item);
}
println!("");
}
}
pub fn get_distance_table(m: usize, n: usize) -> DistanceMatrix {
let mut distances: Vec<Vec<usize>> = Vec::with_capacity(m + 1);
distances.push((0..n + 1).collect());
for i in 1..m + 1 {
distances.push(vec![usize::MAX; n + 1]);
distances[i][0] = i;
}
distances
}