https://school.programmers.co.kr/learn/courses/30/lessons/181859
정답
import java.util.ArrayList;
class Solution {
public int[] solution(int[] arr) {
ArrayList<Integer> list = new ArrayList<>();
for(int i = 0; i < arr.length; i++) {
if(list.isEmpty() || list.get(list.size() - 1) != arr[i]) {
list.add(arr[i]);
} else {
list.remove(list.size() - 1);
}
}
if(list.isEmpty()) {
int[] empty = new int[1];
empty[0] = -1;
return empty;
} else {
int[] answer = new int[list.size()];
for(int i = 0; i < list.size(); i++) {
answer[i] = list.get(i);
}
return answer;
}
}
}
다른 사람의 풀이
import java.util.Stack;
class Solution {
public int[] solution(int[] arr) {
Stack<Integer> stack = new Stack<>();
for (int no : arr) {
if (!stack.isEmpty() && no == stack.peek()) {
stack.pop();
} else {
stack.push(no);
}
}
return stack.isEmpty() ? new int[] { -1 } : stack.stream().mapToInt(i -> i).toArray();
}
}
'Java > 프로그래머스' 카테고리의 다른 글
[JAVA] 프로그래머스 - 배열의 길이를 2의 거듭제곱으로 만들기 (0) | 2024.04.11 |
---|---|
[JAVA] 프로그래머스 - 무작위로 k개의 수 뽑기 (0) | 2024.04.11 |
[JAVA] 프로그래머스 - 빈 배열에 추가, 삭제하기 (0) | 2024.04.10 |
[JAVA] 프로그래머스 - 배열의 원소만큼 추가하기 (0) | 2024.04.10 |
[JAVA] 프로그래머스 - 세 개의 구분자 (0) | 2024.04.10 |