[프로그래머스] 문자열 내 p와 y의 개수 - JavaScript

Hyunji·2022년 1월 17일
0

알고리즘

목록 보기
12/51
post-thumbnail

문제설명

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

제한사항

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

입출력 예시

sanswer
"pPoooyY"true
"Pyy"false

입출력 예시 설명

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

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


문제풀이

function solution(s){
    let change = s.toLowerCase();
    console.log(change);
    let check_p = change.match(/p/g).length;
    console.log(check_p);
    let check_y = change.match(/y/g).length;
    console.log(check_y);
    
    if (check_p == check_y) {
        return true;
    } else {
        return false;
    }
}
두 번째 방법
function solution(s){
    let change = s.toLowerCase();
//    console.log(change);
    let check_p = change.split("p").length;
    let check_y = change.split("y").length;
    
    return check_p == check_y ? true : false;
}
풀이방법

먼저 문자열을 .toLowerCase() 함수를 이용해 소문자로 변환해 주었다. 그리고 .match() 함수를 이용했는데, 정규표현식을 사용해 문자열에 p와 y가 있는지 확인하고 .length 를 이용해서 p와 y의 개수를 각각 check_p, check_y 변수에 저장하였다.
p의 개수와 y의 개수가 동일하면 true, 다르면 false를 반환하기 위해 if문을 이용해서 코드를 작성했다.
프로그래머스에서는 2,3,29,30 테스트 케이스에서 런타임 에러가 떠서 이 코드로 통과는 못 했다.

두 번째 풀이 방법
  • .toLowerCase() 메소드를 이용해서 문자열을 모두 소문자로 변환해준다
  • .split() 메소드를 이용해 check_p 에는 "p" 를 기준으로 문자열을 나눠주고 check_y 에는 "y"를 기준으로 문자열을 나눠준것을 .length() 를 이용해 길이를 저장해준다.
  • check_p 와 check_y 의 길이가 같다면 true를, 다르면 false를 return 한다.
사용한 함수

.toLowerCase()

  • str.toLowerCase() 를 사용하면 문자열을 소문자로 바꿔준다.

.match()

  • 특정 텍스트 안에 검색할 단어, 찾고 싶은 단어가 있는경우 해당 텍스트가 문구에 포함되어 있는지 확인할 수 있다.
    출처 : https://pawo.tistory.com/6

다른 사람의 풀이
function numPY(s){
  //함수를 완성하세요
    return s.toUpperCase().split("P").length === s.toUpperCase().split("Y").length;
}
profile
성장중인 개발자

0개의 댓글