Data Analyst KIM

[프로그래머스Lv.1] 대충 만든 자판 - 파이썬 본문

데이터 분석/Coding Test

[프로그래머스Lv.1] 대충 만든 자판 - 파이썬

김두연 2023. 7. 6. 23:31
반응형
 

프로그래머스

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

programmers.co.kr

[프로그래머스Lv.1] 대충 만든 자판 - 파이썬
[프로그래머스Lv.1] 대충 만든 자판 - 파이썬

 

문제를 이해하는데 오래걸렸다. 

keymap과 targets이 주어지는데 keymap을 활용하여 target의 값이 최소로 눌리는 횟수를 구해야한다.

다음과 같은 코드를 작성할 수 있다.

일단 모두 비교를 해서 리스트에 넣어주고 최솟값을 뽑아서 더해주는 방식으로 코딩을 했다.

 

def solution(keymap, targets):
    answer = [0] * len(targets)
    for t in range(len(targets)):
        for i in range(len(targets[t])):
            save = []  # targets의 값을 keymap의 인덱스와 비교해서 숫자를 추가해서 비교를 하기 위해 만든 방
            for j in range(len(keymap)): 
                if targets[t][i] in keymap[j]: # keymap의 @번인덱스안에 인덱스들의 값이 있는가?
                    save.append(keymap[j].index(targets[t][i])+1) # 있다면 그 값에 해당되는 keymap의 인덱스를 저장
            if len(save) == 0:   # 저장된 값이 없다면 
                answer[t] = -1   # -1을 호출
                break
            else:
                answer[t] += min(save) # save에 내부의 값 중에서 최소값만 answer에 더하라
    return answer
반응형