Written by
java-style
on
on
[level2] 프로그래머스 - 짝지어 제거하기(JAVA)
[level2] 프로그래머스 - 짝지어 제거하기(JAVA)
728x90
[ 문제 풀이 ]
- 앞에서 부터 한 글자씩 스택에 넣는다.
- 단 스택의 제일 위(마지막에 넣은 글자)와 현재 글자가 같은 경우, 글자를 넣지 않고 스택에서 뺀다.
- 만약 스택이 비어있거나, 스택의 위에있는 문자와 다르다면, 스택에 글자를 넣는다.
- 다 처리한 후,
스택이 비어있으면 1, 안 비어있으면 0을 리턴한다.
[ 전체 코드 ]
import java.util.Stack; class Solution { public int solution(String s) { Stack stack = new Stack(); for (int i = 0; i < s.length(); i++) { char ch = s.charAt(i); if (!stack.isEmpty() && ch == stack.peek()) stack.pop(); else stack.add(ch); } return stack.isEmpty() ? 1 : 0; } }
728x90
from http://jisunshine.tistory.com/173 by ccl(A) rewrite - 2021-09-18 23:27:53