문제 설명 :
대문자와 소문자가 섞여있는 문자열 s가 주어집니다. s에 'p'의 개수와 'y'의 개수를 비교해 같으면 True, 다르면 False를 return 하는 solution를 완성하세요. 'p', 'y' 모두 하나도 없는 경우는 항상 True를 리턴합니다. 단, 개수를 비교할 때 대문자와 소문자는 구별하지 않습니다.
예를들어 s가 pPoooyY면 true를 return하고 Pyy라면 false를 return합니다.
제한 조건 :
1. 문자열 s의 길이 : 50 이하의 자연수
2. 문자열 s는 알파벳으로만 이루어져 있습니다.
해결 방법 :
1번 문제 :
1. 주어진 s의 String을 Array로 만들어 보자 생각했습니다.
2. 만든 배열을 하나씩 "P"와 "p", "Y"와 "y"와 비교했습니다.(이 과정에서 toUpperCase or toLowerCase로 하여 둘 중 하나씩만 비교해도 됩니다.)
3. p와 y를 각각 count하여 if문을 통해 비교해 같으면 true, 틀리면 false를 내뱉었습니다.
boolean solution(String s) {
boolean answer = true;
String[] str = s.split("");
int countOfP = 0;
int countOfY = 0;
for(int i=0; i<s.length(); i++) {
if(str[i].equals("P") || str[i].equals("p")) {
countOfP++;
} else if(str[i].equals("Y") || str[i].equals("y")) {
countOfY++;
}
}
if(countOfP == countOfY) answer = true;
else answer = false;
// [실행] 버튼을 누르면 출력 값을 볼 수 있습니다.
System.out.println("Hello Java");
return answer;
}
2번 문제 :
1. 솔직히 이건 답을 봤습다. filter를 통해 구현한건데, 이 부분은 제가 안드로이드에서 작업하다보니 안돌아가서 답만 실행시켜봤습니다.
boolean solution(String s) {
boolean answer = true;
s = s.toUpperCase();
answer = s.chars().filter(e -> 'P' == e).count() == s.chars().filter(e -> 'Y' == e).count();
return answer;
}
이런 식으로 작동합니다. 이 문제도 쉬웠지만, 다양한 풀이 방법이 있네요!
'Algorithm > 프로그래머스' 카테고리의 다른 글
프로그래머스 level1 문제 : 문자열 다루기 기본(java) (0) | 2018.10.18 |
---|---|
프로그래머스 level1 문제 : 문자열 내 마음대로 정렬하기(java) (2) | 2018.10.17 |
프로그래머스 level1 문제 : 두 정수 사이의 합(java) (0) | 2018.10.16 |
프로그래머스 level1 문제 : 같은 숫자는 싫어(java) (0) | 2018.10.16 |
프로그래머스 level1 문제 : 체육복(java) (0) | 2018.10.14 |