소소한 컴퓨터 이야기

문자열 내 p와 y의 개수

by Cori

문제

대문자와 소문자가 섞여있는 문자열 s가 주어집니다.

s에 'p'의 개수와 'y'의 개수를 비교해 같으면 True, 다르면 False를 return 하는 solution 함수를 완성하세요.

'p', 'y' 모두 하나도 없는 경우는 항상 True를 리턴합니다. 단, 개수를 비교할 때 대문자와 소문자는 구별하지 않습니다.

 

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

 

제한사항

· 문자열 s의 길이: 50 이하의 자연수

· 문자열 s는 알파벳으로만 이루어져 있습니다.

 

입출력 예

s answer
'pPoooyY' true
'Pyy' false 

풀이

1. Me

def solution(s):
    answer = True
    p_cnt=0; y_cnt=0
    for i in s:
        if i in ['p','P']:
            p_cnt += 1
        elif s[i] in ['y','Y']:
            y_cnt += 1
    return False if p_cnt != y_cnt else True

in 연산자를 활용하여, 'p', 'P'에 해당하는 문자가 있으면 p_cnt를 1 증가시키고, 'y','Y'에 해당하는 문자가 있으면 y_cnt를 1 증가시켜 둘을 비교.. 삼항연산자를 활용하여 return 부분을 단순화하였다. 

 

* 삼항연산자는 [on_true] if [조건식] else [on_false]와 같은 형태로 사용 

 

2. Others

def numPY(s):
    return s.lower().count('p') == s.lower().count('y')

문제에서 대, 소문자 상관하지 않는다고 명시하였으므로, 문자열을 모두 소문자로 통일하였다. 더 나아가, count() 함수를 사용하여 문자열 내에 존재하는 알파벳의 개수를 구하고, 이들을 비교하였다.

'CS > Coding Test' 카테고리의 다른 글

나누어 떨어지는 숫자 배열  (0) 2021.08.22
두 정수 사이의 합  (0) 2021.08.21
문자열 다루기 기본  (0) 2021.08.21
서울에서 김서방 찾기  (0) 2021.08.21
수박수박수박수박수 ?  (0) 2021.08.21

블로그의 정보

코딩하는 오리

Cori

활동하기