NIRVANA

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

Coding test(Python3)/스터디

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

녜잉 2024. 5. 18. 19:49

 

문제

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

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

제한사항

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

 

문제 풀이 접근1

1) 문자열 S에 lower()함수를 사용하여 문자열 s내의 모든 문자를 소문자로 변경한다.

2) s에 count()함수를 사용하여 각각 p와 y의 개수가 몇개인지 확인한다.

3) p와 y의 수가 같다면 true를, 다르다면 false를 반환한다.

def solution(s):
    answer = True
    
    count_p = 0
    count_y = 0
    
    s = s.lower()
    
    count_p = s.count('p')
    count_y = s.count('y')
    
    if count_p == count_y:
        answer= True

    else:
        answer = False
    

    return answer

 

 

 

다른 분들 문제 풀이

def numPY(s):
    # 함수를 완성하세요
    return s.lower().count('p') == s.lower().count('y')



# 아래는 테스트로 출력해 보기 위한 코드입니다.
print( numPY("pPoooyY") )
print( numPY("Pyy") )

 

헐 이게 이렇게 한 줄도 되는 코드였어...???

진짜 간결하게 짤 수 있는 건 간결하게 짜면 좋으니까....

담번부터는 코드 생각할 때 어떻게 하면 간결하게 만들 수 있을지도 같이 고민해봐야할 듯..!!