-
Notifications
You must be signed in to change notification settings - Fork 820
/
ReconstructOriginalDigitsFromEnglish.java
97 lines (93 loc) · 3.25 KB
/
ReconstructOriginalDigitsFromEnglish.java
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/* (C) 2024 YourCompanyName */
package string;
import java.util.*;
/**
* Created by gouthamvidyapradhan on 04/06/2019 Given a non-empty string containing an out-of-order
* English representation of digits 0-9, output the digits in ascending order.
*
* <p>Note: Input contains only lowercase English letters. Input is guaranteed to be valid and can
* be transformed to its original digits. That means invalid inputs such as "abc" or "zerone" are
* not permitted. Input length is less than 50,000. Example 1: Input: "owoztneoer"
*
* <p>Output: "012" Example 2: Input: "fviefuro"
*
* <p>Output: "45"
*
* <p>Solution: O(N) General idea is to note some unique characters in english representation of a
* digit such as 'x' 'x' can occur only in digit 6, similarly for 'z' it can occur only for digit 0
* and likewise. Keep a character frequency hashmap and decrement the count as and when a new digit
* is formed. Sort the digits and return a concatenated string.
*/
public class ReconstructOriginalDigitsFromEnglish {
public static void main(String[] args) {
System.out.println(
new ReconstructOriginalDigitsFromEnglish()
.originalDigits(
"fviefurofviefurofviefurofviefurofviefurofviefurofviefurofviefurofviefurofviefuro"));
}
public String originalDigits(String s) {
Map<Character, Integer> map = new HashMap<>();
for (char c : s.toCharArray()) {
map.putIfAbsent(c, 0);
map.put(c, map.get(c) + 1);
}
Map<Integer, Integer> intMap = new HashMap<>();
if (map.containsKey('x')) {
update(map, intMap, 6, 'x', Arrays.asList('s', 'i', 'x'));
}
if (map.containsKey('g')) {
update(map, intMap, 8, 'g', Arrays.asList('e', 'i', 'g', 'h', 't'));
}
if (map.containsKey('w')) {
update(map, intMap, 2, 'w', Arrays.asList('t', 'w', 'o'));
}
if (map.containsKey('z')) {
update(map, intMap, 0, 'z', Arrays.asList('z', 'e', 'r', 'o'));
}
if (map.containsKey('u')) {
update(map, intMap, 4, 'u', Arrays.asList('f', 'o', 'u', 'r'));
}
if (map.containsKey('f')) {
update(map, intMap, 5, 'f', Arrays.asList('f', 'i', 'v', 'e'));
}
if (map.containsKey('v')) {
update(map, intMap, 7, 'v', Arrays.asList('s', 'e', 'v', 'e', 'n'));
}
if (map.containsKey('i')) {
update(map, intMap, 9, 'i', Arrays.asList('n', 'i', 'n', 'e'));
}
if (map.containsKey('t')) {
update(map, intMap, 3, 't', Arrays.asList('t', 'h', 'r', 'e', 'e'));
}
if (map.containsKey('o')) {
update(map, intMap, 1, 'o', Arrays.asList('o', 'n', 'e'));
}
Set<Integer> keys = intMap.keySet();
List<Integer> list = new ArrayList<>(keys);
list.sort(Comparator.comparingInt(o -> o));
StringBuilder sb = new StringBuilder();
for (int i : list) {
int count = intMap.get(i);
while (count-- > 0) {
sb.append(i);
}
}
return sb.toString();
}
private void update(
Map<Character, Integer> map,
Map<Integer, Integer> intMap,
int num,
char id,
List<Character> list) {
if (map.containsKey(id)) {
int count = map.get(id);
intMap.put(num, count);
while (count-- > 0) {
for (char c : list) {
map.put(c, map.get(c) - 1);
}
}
}
}
}