Welcome! Everything is fine.

[프로그래머스/Lv.1] 옹알이(2) - Java 본문

프로그래머스/Lv.1

[프로그래머스/Lv.1] 옹알이(2) - Java

개발곰발 2024. 4. 27.
728x90

📌 문제

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

📌 풀이 - replaceAll() 활용

babbling 배열에서 머쓱이의 조카가 발음할 수 있는 단어의 개수를 반환하는 문제였다. 네 가지 발음을 조합해서 만들 수 있는 발음을 할 수 있다는 조건은 쉬웠지만 연속해서 같은 발음을 하지 못한다는 조건을 보고 고민에 빠졌다. 다시 생각해보니 "aya", "ye", "woo", "ma" 네 가지 발음을 먼저 지우고 연속된걸 지우려고 해서 답이 나오지 않았던 것..🙄  먼저 연속되는 발음을 공백으로 처리한 뒤(공백이 아니어도 됨, 그저 비어있는 문자열이 아니도록 만들기) 네 가지 발음이 나올 시 지워준다. 그리고나서 해당 문자열이 ㅣ완전히 비어있다면 answer 값을 1 증가시킨다. 네가지 발음 중 하나가 나오더라도 연속된 발음이 들어갔다면 비어있는 문자열이 아니게 되어서 answer 값이 증가하지 않는다.

for (String s : babbling) {
    s = s.replaceAll("ayaaya|yeye|woowoo|mama", " ");
    s = s.replaceAll("aya|ye|woo|ma", "");
    if (s.isEmpty()) answer++;
}

 

replaceAll()을 사용할 때 자주 쓰일만한 정규식은 그냥 외워놓자..!

📌 전체 코드

class Solution {
    public int solution(String[] babbling) {
        int answer = 0;
        
        for (String s : babbling) {
            s = s.replaceAll("ayaaya|yeye|woowoo|mama", " ");
            s = s.replaceAll("aya|ye|woo|ma", "");
            if (s.equals("")) answer++;
        }
        
        return answer;
    }
}