문제
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
알고리즘
스택
풀이
s를 탐색하면서
stack의 top에 있는 값이 현재 원소와 동일하다면 제거하고, 그렇지 않다면 stack에 삽입한다.
탐색이 끝난 후 스택이 비어있다면 모두 제거할 수 있는 문자열이므로 1을,
스택이 비어있지 않다면 0을 반환한다.
코드
import java.util.*;
class Solution
{
public int solution(String s)
{
Stack<Character> stack = new Stack<>();
for(int i=0; i< s.length(); i++) {
char c = s.charAt(i);
if(!stack.isEmpty() && stack.peek() == c)
stack.pop();
else
stack.push(c);
}
return stack.isEmpty() ? 1 : 0;
}
}
'Algorithm > 프로그래머스' 카테고리의 다른 글
[프로그래머스] 점프와 순간 이동 (Java) (0) | 2022.11.07 |
---|---|
[프로그래머스] 배달 (Java) (0) | 2022.11.07 |
[프로그래머스] N개의 최소공배수 (Java) (0) | 2022.11.07 |
[프로그래머스] 최솟값 만들기 (Java) (0) | 2022.11.07 |
[프로그래머스] JadenCase 문자열 만들기 (Java) (0) | 2022.11.07 |