본문 바로가기
코드문제풀이/JAVA

[자바] 문자열 내 p와 y의 개수

by 똥쟁이핑크 2023. 7. 10.

https://school.programmers.co.kr/learn/courses/30/lessons/12916?language=java 

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

문제 설명

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

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

 

제한사항

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

 

입출력 예

s answer
"pPoooyY" true
"Pyy" false

 

입출력 예 설명

입출력 예 #1
'p'의 개수 2개, 'y'의 개수 2개로 같으므로 true를 return 합니다.

 

입출력 예 #2
'p'의 개수 1개, 'y'의 개수 2개로 다르므로 false를 return 합니다.

 

나의 문제 풀이 

1 - 1)  대소문자 상관없이 카운트가 가능하므로 s를 소문자로 변환하였다.

1 - 2) 문자 하나씩 비교하기 위해 char 배열로 만들었다.

1 - 3) 카운트를 세기위해 p라는 변수를 만들었다.

1 - 4) for문으로 배열을 돌면서 i 번째 인덱스에 있는 숫자가 p의 아스키 코드 112와 같으면 +1

1 - 5) y의 아스키 코드 121과 같으면 -1을 하였다.

1 - 6) p == 0 이면 p와 y의 개수가 같으니 true을 반환하게 하였지만 채점시 실패

 

2 - 1) 처음부터 String 배열로 만들기 위헤 소문자로 변환한후  split("") 하였다.

2 - 2) 똑같이 p라는 변수는 숫자를 세기 위해 0으로 설정하였다.

2 - 3) equals()를 사용하여 p와 y를 비교하여 p이면 +1 y이면 -1이 되게 하였다.

2 - 4) 마지막으로 동일하게 p == 0 이면 p와 y의 개수가 같으니 true을 반환하게 하였고 아니면  false를 반환하게 하였다.

 

 

// 첫 번째 코드(채점하기에서 실패)
class Solution {
    boolean solution(String s) {
        boolean answer = true;
        String s1 = s.toLowerCase();
        char[] s2 = s.toCharArray();
        int p = 0;
        for(int i = 0; i < s2.length; i++){
            if(s2[i] == 112){
                p++; 
            }
            else if (s2[i] == 121){
                p--;
            }
        }

        return p == 0 ;
    }
}


// 최종 코드
class Solution {
    boolean solution(String s) {
        boolean answer = true;
        String[] s1 = s.toLowerCase().split("");
        int p = 0;
        
        for(int i = 0; i < s1.length; i++){
            if("p".equals(s1[i])){
                p++;
            }
            else if("y".equals(s1[i])){
                p--;
            }
        }

        return p == 0 ;
    }
}