머쓱이는 태어난 지 11개월 된 조카를 돌보고 있습니다. 조카는 아직 "aya", "ye", "woo", "ma" 네 가지 발음과 네 가지 발음을 조합해서 만들 수 있는 발음밖에 하지 못하고 연속해서 같은 발음을 하는 것을 어려워합니다. 문자열 배열 babbling이 매개변수로 주어질 때, 머쓱이의 조카가 발음할 수 있는 단어의 개수를 return하도록 solution 함수를 완성해주세요.
class Solution {
public int solution(String[] babbling) {
int answer = 0;
String arr[] = {"aya", "ye", "woo", "ma"}; // 기본값
String arrs[] = {"ayaaya", "yeye", "woowoo", "mama"}; // 연속값
for (int i = 0; i < babbling.length; i++) {
String an = babbling[i];
String ans = babbling[i];
for (int j = 0; j < arr.length; j++) {
if (!ans.equals(ans.replace(arrs[j], ""))) {
break;
// 만약 연속값이 있을경우 답이아니므로 다음문자열로 넘어감
}
an = an.replace(arr[j], " ");
// 만약""으로 대체했을때 없어진 문자의 앞과 뒤의 문자가 합쳐져
// 이상한문자열이 되므로 띄워쓰기로 우선 대체함
}
an = an.replace(" ", "");
// 띄워쓰기로 대체한값 다시 제거하기
if (an == "") {
answer++;
}
// 모두 제거되었을시 0이므로 answer++
}
return answer;
}
}