(Java/자바) 프로그래머스 Lv1 - 문자열 내 p와 y의 개수

문제설명

대문자와 소문자가 섞여있는 문자열 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 합니다.

 


charAt()

이 문제를 풀기 위해 charAt() 메서드를 사용했습니다.

 

charAt() 메서드를 이용하면, 아래처럼 문자열 "Hevlog"charAt(index)을 통해서 인덱스 번째 문자 받아올 수 있습니다

아래의 코드를 실행하면 Hevlog 문자열 0번째 : H, 1번째 : e, 2번째 : v, 5번째 : g 를 받아온 것을 볼 수 있습니다.

		String str = "Hevlog";		
		System.out.println(str.charAt(0)); 
		System.out.println(str.charAt(1));
		System.out.println(str.charAt(2)); 
		System.out.print(str.charAt(5));

출력 결과

 

또한 charAt() 메서드를 이용해 숫자를 받아 올 수도 있습니다.

아래 출력결과를 보면  CODE 문자열을 (int) 정수로 받아 0번째 C : 67 , 1번째 O : 79, 2번째 D : 68, 3번째 E : 69유니코드 숫자를 가져옵니다.

		String a = "CODE"; 
		int c = a.charAt(0);
		int o = a.charAt(1);
		int d = a.charAt(2);
		int e = a.charAt(3);

		System.out.println(c);
		System.out.println(o);
		System.out.println(d);
		System.out.println(e);

출력 결과

 

Solution.java

class Solution {
    boolean solution(String s) {
        s = s.toLowerCase();
        int cntP = 0;
        int cntY = 0;
        for (int i = 0; i < s.length(); i++) {
            char ch = s.charAt(i);
            if (ch == 'p') cntP++;
            if (ch == 'y') cntY++;
        }
        
        return cntP == cntY ? true : false;
        

    }
}

 

코드 해설

s 는 pPoooyY라고 가정하고 설명하겠습니다.

 

  1. s를 .toLowerCase() 메서드를 이용해 소문자로 변환 합니다 => ppoooyy
  2. ppoooyy 문자열에서 p를 찾으면 카운팅하기 위해 (int)cntP 변수를 선언합니다.
  3. 마찬가지로 y를 찾으면 카운팅하기 위해 (int)cntY 변수를 선언합니다.
  4. for 문을 통해 ppoooyy 문자열의 0번째 부터 ppoooyy.length (7) 전인 6까지 순환합니다.
  5. 0번째 부터 6번재까지 문자열을 하나씩 비교하여 p와 y를 찾기 위해 s.charAt(i) 를 이용합니다. 
  6. i 가 0 부터 6까지 순환하면서 p를 찾으면 cntP 변수의 값을 1씩 증감합니다.
  7. i 가 0 부터 6까지 순환하면서 y를 찾으면 cntY 변수의 값을 1씩 증감합니다.
  8. 삼항연산자를 통해 cntP의 값과 cntY의 값이 같다면 true를 반환하고 아니라면 false를 반환합니다.