forked from fishercoder1534/Leetcode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path_942.java
26 lines (24 loc) · 861 Bytes
/
_942.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
package com.fishercoder.solutions;
import java.util.ArrayDeque;
import java.util.Queue;
public class _942 {
public static class Solution1 {
public int[] diStringMatch(String S) {
Queue<Integer> deque = new ArrayDeque<>();
for (int i = 0; i <= S.length(); i++) {
deque.add(i);
}
int[] result = new int[S.length() + 1];
for (int i = 0; i <= S.length(); i++) {
if (i == S.length()) {
result[i] = ((ArrayDeque<Integer>) deque).pollLast();
} else if (S.charAt(i) == 'I') {
result[i] = ((ArrayDeque<Integer>) deque).pollFirst();
} else {
result[i] = ((ArrayDeque<Integer>) deque).pollLast();
}
}
return result;
}
}
}