옹알이 java

정하윤·2023년 3월 6일
0

문제 설명

머쓱이는 태어난 지 11개월 된 조카를 돌보고 있습니다. 조카는 아직 "aya", "ye", "woo", "ma" 네 가지 발음과 네 가지 발음을 조합해서 만들 수 있는 발음밖에 하지 못하고 연속해서 같은 발음을 하는 것을 어려워합니다. 문자열 배열 babbling이 매개변수로 주어질 때, 머쓱이의 조카가 발음할 수 있는 단어의 개수를 return하도록 solution 함수를 완성해주세요.

제한사항

  • 1 ≤ babbling의 길이 ≤ 100
  • 1 ≤ babbling[i]의 길이 ≤ 30
  • 문자열은 알파벳 소문자로만 이루어져 있습니다.



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;
  }
}


0개의 댓글