[99클럽 코테 스터디 3일차 TIL] 문자열 갯수 구하기

sarah·2024년 7월 25일
0

programmers

목록 보기
3/21

문제

  • 문제 설명
    대문자와 소문자가 섞여있는 문자열 s가 주어집니다. s에 'p'의 개수와 'y'의 개수를 비교해 같으면 True, 다르면 False를 return 하는 solution를 완성하세요. 'p', 'y' 모두 하나도 없는 경우는 항상 True를 리턴합니다. 단, 개수를 비교할 때 대문자와 소문자는 구별하지 않습니다.

예를 들어 s가 "pPoooyY"면 true를 return하고 "Pyy"라면 false를 return합니다.

  • 제한사항
    문자열 s의 길이 : 50 이하의 자연수
    문자열 s는 알파벳으로만 이루어져 있습니다.

class Solution {
    boolean solution(String s) {
        s = s.toLowerCase();
        
        int countOfP = 0;
        int countOfY = 0;
        
        for(int i = 0; i < s.length(); i++) {
            char ch = s.charAt(i);
            if(ch == 'p') {
                countOfP++;
            }
            if(ch == 'y') {
                countOfY++;
            }
        }

        return countOfP == countOfY;
    }
}

해결방안

  • 문자를 소문자로 변경 -> for문으로 charAt해서 문자 비교 -> 갯수비교

회고

  • 다른사람이 푼 답안 중 가장 깔끔해서 만족했던 코드
class Solution {
    boolean solution(String s) {
        s = s.toUpperCase();

        return s.chars().filter( e -> 'P'== e).count() == s.chars().filter( e -> 'Y'== e).count();
    }
}

0개의 댓글