1 분 소요

문제

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

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

입출력 예시

s return
"pPoooyY" true
"Pyy" false

문제풀이

나의 풀이

function solution(s){
    const splitedS = s.split("")
    const one = [];
    const two = [];
    splitedS.map( i => {
        if(i === "p" || i === "P") {
            one.push(i);
        }else if(i === "y" || i === "Y"){
            two.push(i);
        }
    })
  if(one.length === two.length) {
    return true
  } else if (one.length === 0 && two.length === 0 ){
    return true
  } else {
    return false
  }
}

1) 문자열을 쪼개준다(split)
2) 2개의 배열을 만들어서 문자를 해당 배열에 넣어준다.
2-1) map을 사용해 매개변수와 p,P,y,Y를 비교해 배열에 넣는다.
3) 각 조건에 맞게 조건문을 만들어준다.

다른 사람 풀이

return s.toUpperCase().split("P").length === s.toUpperCase().split("Y").length;

해당 문제는 내가 푼 테스트 케이스와는 다르지만 사고의 전환을 했다는 부분이 놀랍고 신기해 가지고 와보았다. 문제의 조건을 잘 보고 간단히 할 수 있는 부분을 간단하게 만들어 풀었다는 점이 놀랍다.

1) 조건에 대,소문자를 구분하지 않는다고 했기에 toUpperCase()를 사용해 모든 문자열을 대문자로 변환한다.
2) 변환한 대문자로 쪼갠뒤 그 길이를 비교한다.

댓글남기기