Я хочу сортировать данные HashMap по значению в Rust (например, при подсчете частоты символов в строке).
Python эквивалент того, что я пытаюсь сделать:
count = {}
for c in text:
count[c] = count.get('c', 0) + 1
sorted_data = sorted(count.items(), key=lambda item: -item[1])
print('Most frequent character in text:', sorted_data[0][0])
Мой соответствующий код ржавчины выглядит следующим образом:
// Count the frequency of each letter
let mut count: HashMap<char, u32> = HashMap::new();
for c in text.to_lowercase().chars() {
*count.entry(c).or_insert(0) += 1;
}
// Get a sorted (by field 0 ("count") in reversed order) list of the
// most frequently used characters:
let mut count_vec: Vec<(&char, &u32)> = count.iter().collect();
count_vec.sort_by(|a, b| b.1.cmp(a.1));
println!("Most frequent character in text: {}", count_vec[0].0);
Является ли эта идиоматическая ржавчина? Могу ли я построить count_vec
таким образом, чтобы он использовал данные HashMaps и владел им (например, используя map()
)? Будет ли это более именованным?