[알고리즘] 문자열 내 p와 y의 개수

Cottonmycotton·2021년 9월 28일
0

Algorithm

목록 보기
16/44
post-custom-banner

문제 설명

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

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

제한사항

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

입출력 예시

🖊 풀이

  • 개수를 비교할 때 대문자나 소문자 구분이 없기 때문에 메서드를 사용하여 대문자 또는 소문자로 변환시킨다.
  • for문을 사용하여 p또는 y가 있을 경우 각각 다른 배열에 넣어준다.
  • 배열의 길이가 같으면 true, 다르면 false를 반환한다.

📌 toUpperCase()

  • 문자열을 대문자로 변환해 반환한다.

📌 toLowerCase()

  • 문자열을 소문자로 변환해 반환한다.

📌 includes

  • 문자열 내에 특정 문자가 포함되어 있는지 판별하고 불리언값으로 반환한다.
  • inclides메서드를 사용하여 문자열 내에 p와 y가 모두 없을 경우를 처리한다.

💡 코드

function solution(s) {
	let answer = '';
	const pList = [];
	const yList = [];

	if (s.length <= 50) {
		const lowerLetter = s.toLowerCase();

	 if (!lowerLetter.includes('p') && !lowerLetter.includes('y') {
			return true;
		}

		for (let i = 0; i < lowerLetter.length; i++) {
			if (lowerLetter[i] === 'p') {
				pList.push('p');
			} else if (lowerLetter[i] === 'y') {
				yList.push('y');
			}
		}

		if (pList.length === yList.length) {
			answer = true;
		} else if (pList.length !== yList.length) {
			answer = false;
		}
	}

	return answer;
}

문제 출처: 프로그래머스

profile
투명인간
post-custom-banner

0개의 댓글