감자튀김 공장🍟

[프로그래머스/Lv.2] 모음사전 (with 파이썬) 본문

Algorithm/Programmers

[프로그래머스/Lv.2] 모음사전 (with 파이썬)

Potato potage 2023. 9. 13. 23:20
반응형

✔ 문제

문제 설명

사전에 알파벳 모음 'A', 'E', 'I', 'O', 'U'만을 사용하여 만들 수 있는, 길이 5 이하의 모든 단어가 수록되어 있습니다. 사전에서 첫 번째 단어는 "A"이고, 그다음은 "AA"이며, 마지막 단어는 "UUUUU"입니다.

단어 하나 word가 매개변수로 주어질 때, 이 단어가 사전에서 몇 번째 단어인지 return 하도록 solution 함수를 완성해주세요.

 

제한사항
  • word의 길이는 1 이상 5 이하입니다.
  • word는 알파벳 대문자 'A', 'E', 'I', 'O', 'U'로만 이루어져 있습니다.

 

입출력 예

word result
"AAAAE" 6
"AAAE" 10
"I" 1563
"EIO" 1189

풀이

def solution(word):
    answer = 0
    words = ["A", "E", "I", "O", "U"]
    char = [781, 156, 31, 6, 1]
    
    for i in range(len(word)):
        answer += words.index(word[i]) * char[i] + 1
    
    return answer

✔ 설명

규칙

최대 5자리 단어로 이루어져 있으며

각 자리는 이전 자리의 가중치 [5^4, 5^3, 5^2, 5^1, 5^0] 를 가진다.

 

AAAAE 에서 E 위치의 가중치는 1

AAAE 에서 E 위치의 가중치는 5 + 1인 6이 된다.

AAE에서 E 위치의 가중치는 31이 된다. (25 + 5 + 1, 5^2 + 5^1 + 5^ 0)

 

따라서 각 자리의 가중치는 [781, 156, 31, 6, 1] 임을 알 수 있다.

 

각 자릿수가 필요한 연산 횟수 * 알파벳 리스트의 인덱스 + 1을 하며 값을 구하면 된다.


 

✔ 후기

5의 제곱으로 어떤 규칙이 있을 것이라고 감은 잡았지만 자릿수가 늘어날수록 5의 제곱으로만 늘어나는 것이 아니라 전 가중치들을 더하여 늘어나는 것을 금방 깨닫지 못했었다.

 


✔ 참고

https://school.programmers.co.kr/questions/40485

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

https://school.programmers.co.kr/questions/44442

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

반응형
Comments