-
-
Notifications
You must be signed in to change notification settings - Fork 610
/
Copy pathFindAndReplaceString.java
60 lines (50 loc) · 1.55 KB
/
FindAndReplaceString.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
package problems.medium;
import java.util.Arrays;
import java.util.Comparator;
/**
* Why Did you create this class? what does it do?
*/
public class FindAndReplaceString {
public static void main(String[] args) {
System.out.println(new FindAndReplaceString().findReplaceString("abcd", new int[] {
0, 2
}, new String[] {
"a", "cd"
}, new String[] {
"eee", "ffff"
}));
}
public String findReplaceString(String s, int[] indexes, String[] sources, String[] targets) {
if (s == null || s.length() == 0)
return s;
StringBuilder sb = new StringBuilder();
int k = 0;
Pair[] p = new Pair[indexes.length];
for (int i = 0; i < p.length; i++) {
p[i] = new Pair(i, indexes[i]);
}
Arrays.sort(p, Comparator.comparingInt(a -> a.val));
int i = 0;
for (int j = 0; j < s.length(); j++) {
if (i < p.length && p[i].val == j) {
if (s.substring(p[i].val, p[i].val + sources[p[i].id].length()).equals(sources[p[i].id])) {
sb.append(targets[p[i].id]);
j += sources[p[i].id].length() - 1;
} else {
sb.append(s.charAt(j));
}
i++;
} else {
sb.append(s.charAt(j));
}
}
return sb.toString();
}
class Pair {
int id, val;
Pair(int i, int v) {
id = i;
val = v;
}
}
}