-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathreconstruct-original-digits-from-english.rs
69 lines (62 loc) · 1.97 KB
/
reconstruct-original-digits-from-english.rs
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#![allow(dead_code, unused, unused_variables)]
fn main() {
assert_eq!(
"012".to_string(),
Solution::original_digits("owoztneoer".to_string())
);
assert_eq!(
"0123456789".to_string(),
Solution::original_digits("zeroonetwothreefourfivesixseveneightnine".to_string())
);
}
struct Solution;
impl Solution {
// zero
// one
// two
// three
// four
// five
// six
// seven
// eight
// nine
// efghinorstuvwxz
pub fn original_digits(s: String) -> String {
let mut l = [0; 26];
let mut count = [0; 10]; // 用于记录每个数字的出现次数
for &i in s.as_bytes().iter() {
l[(i - 97) as usize] += 1;
}
let mut s = String::new();
for &i in "zwuxghfsin".as_bytes().iter() {
if i == b'z' {
count[0] += l[(i - 97) as usize]
} else if i == b'w' {
count[2] += l[(i - 97) as usize]
} else if i == b'u' {
count[4] += l[(i - 97) as usize]
} else if i == b'x' {
count[6] += l[(i - 97) as usize]
} else if i == b'g' {
count[8] += l[(i - 97) as usize]
} else if i == b'h' {
count[3] += l[(i - 97) as usize] - count[8] // 三的数量是h的数量剪掉8的数量
} else if i == b'f' {
count[5] += l[(i - 97) as usize] - count[4]
} else if i == b's' {
count[7] += l[(i - 97) as usize] - count[6]
} else if i == b'i' {
count[9] += l[(i - 97) as usize] - count[6] - count[5] - count[8]
} else if i == b'n' {
count[1] += l[(i - 97) as usize] - count[7] - count[9] * 2 // 因为nine是两个n
}
}
for (i, &v) in count.iter().enumerate() {
if v != 0 {
s.push_str(i.to_string().repeat(v).as_str());
}
}
s
}
}