문제 링크
https://school.programmers.co.kr/learn/courses/30/lessons/12916
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
프로그래머스 문제로 '문자열 내 p와 y의 개수'를 비교하여 True or False를 return 하는 문제이다.
문제 설명
대문자와 소문자가 섞여있는 문자열 s가 주어집니다. s에 'p'의 개수와 'y'의 개수를 비교해 같으면 True, 다르면 False를 return 하는 solution를 완성하세요. 'p', 'y' 모두 하나도 없는 경우는 항상 True를 리턴합니다. 단, 개수를 비교할 때 대문자와 소문자는 구별하지 않습니다.
예를 들어 s가 "pPoooyY"면 true를 return하고 "Pyy"라면 false를 return합니다.
제한사항
문자열 s의 길이 : 50 이하의 자연수문자열 s는 알파벳으로만 이루어져 있습니다.
입출력 예 설명
'p'의 개수 2개, 'y'의 개수 2개로 같으므로 true를 return
입출력 예 #2
'p'의 개수 1개, 'y'의 개수 2개로 다르므로 false를 return
💻내가 짠 코드
def solution(s):
np = 0
ny = 0
for i in range(len(s)):
if(s[i] == 'p' or s[i] == 'P'):
np += 1
elif(s[i] == 'y' or s[i] =='Y'):
ny += 1
if(np == ny):
return True
else:
return False
✍ 접근 방법
문자열 s에서 p와 y를 찾는 반복문으로 각각의 p와 y의 개수를 구하고, 개수를 비교할 때 대문자와 소문자는 구별하지 않기 때문에 소문자와 대문자 개수를 모두 구한다. p의 개수와 y의 개수가 같으면 True를 Return하고 다르면 False를 Return하게 했다.
💡 다른 풀이
def numPY(s):
return s.lower().count('p') == s.lower().count('y')
대문자를 소문자로 바꿀 생각은 했었는데 count 함수를 사용할 생각은 못했기도 했고 이렇게 간결하게 코드를 짤 수 있다는 것에 놀랐다. 아직 배울게 많은데 앞으로 TIL을 통해 다양한 코드를 접해볼 수 있을 것 같아 기대된다.
'Study > Python' 카테고리의 다른 글
[99클럽 코테 스터디] 6일차 TIL - 할리갈리 (0) | 2025.01.21 |
---|---|
[99클럽 코테 스터디] 5일차 TIL - 세로읽기 (0) | 2025.01.18 |
[99클럽 코테 스터디] 4일차 TIL - 뜨거운 붕어빵 (0) | 2025.01.16 |
[99클럽 코테 스터디] 3일차 TIL - 문자열 반 (0) | 2025.01.15 |
[99클럽 코테 스터디] 2일차 TIL - 그대로 출력하기 (0) | 2025.01.14 |