Notice
Recent Posts
Recent Comments
Link
Welcome! Everything is fine.
[프로그래머스/Lv.1] 옹알이(2) - Java 본문
728x90
📌 문제
📌 풀이 - 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;
}
}
'프로그래머스 > Lv.1' 카테고리의 다른 글
[프로그래머스/Lv.1] 둘만의 암호 - Java (0) | 2024.04.29 |
---|---|
[프로그래머스/Lv.1] 숫자 짝꿍 - Java (0) | 2024.04.27 |
[프로그래머스/Lv.1] 실패율(2019 KAKAO BLIND RECRUITMENT) - Java (0) | 2024.04.25 |
[프로그래머스/Lv.1] 햄버거 만들기 - Java (0) | 2024.04.25 |
[프로그래머스/Lv.1] 덧칠하기 - Java (0) | 2024.04.23 |