Skip to content

Commit 14c97cc

Browse files
committed
Upsert 1338-reduce-array-size-to-the-half.rs
1 parent 9295659 commit 14c97cc

File tree

1 file changed

+24
-0
lines changed

1 file changed

+24
-0
lines changed

1338-reduce-array-size-to-the-half.rs

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
pub fn min_set_size(arr: Vec<i32>) -> i32 {
2+
let arr_len = arr.len();
3+
use std::collections::HashMap;
4+
let mut mmp = HashMap::new();
5+
for e in arr {
6+
mmp.entry(e).and_modify(|e|*e+=1).or_insert(1);
7+
}
8+
let mut mmp_vec: Vec<_> = mmp.iter().collect();
9+
mmp_vec.sort_by(|b, a|a.1.cmp(&b.1));
10+
let mut tmp = 0;
11+
let mut ret = 0;
12+
for p in mmp_vec {
13+
tmp += p.1;
14+
ret += 1;
15+
if tmp >= arr_len / 2 { break }
16+
}
17+
ret
18+
}
19+
20+
fn main() {
21+
println!("{:?}", min_set_size(vec![3, 3, 3, 3, 5, 5, 5, 2, 2, 7]));
22+
println!("{:?}", min_set_size(vec![7, 7, 7, 7, 7, 7]));
23+
println!("{:?}", min_set_size(vec![1, 9]));
24+
}

0 commit comments

Comments
 (0)