hye-log

[프로그래머스]위장(Python) 본문

CodingTest/Programmers

[프로그래머스]위장(Python)

iihye_ 2022. 10. 26. 01:29

0. 문제 링크

https://school.programmers.co.kr/learn/courses/30/lessons/42578

 

프로그래머스

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

programmers.co.kr

 

1. 문제 설명

1) 서로 다른 옷의 조합의 수 구하기

 

2. 입출력

# input
clothes = [["yellow_hat", "headgear"], ["blue_sunglasses", "eyewear"], ["green_turban", "headgear"]]

# output
return = 5

 

3. 코드

def solution(clothes):
    closet = {}
    answer = 1

    for cloth in clothes:
        if cloth[1] in closet.keys():               # 종류가 key에 있으면
            closet[cloth[1]].append(cloth[0])       # 해당 key에 item 넣기
        else:                                       # 종류가 key에 없으면
            closet[cloth[1]] = [cloth[0]]           # key 만들고 item 넣기

    for i in closet.values():
        answer *= len(i) + 1                        # value + 1 곱하기

    return answer-1

 

실행 결과

 

4. 회고

옷의 종류는 얼굴, 상의, 하의, 겉옷으로 나뉘어져 있기 때문에 이를 딕셔너리에 저장하는 방식으로 문제를 해결했다. 모든 옷의 종류가 주어지는 게 아니기 때문에 옷의 종류를 보고 key로 등록하고, 처음 보는 옷의 종류이면 새롭게 key로 정의한다. 옷의 종류별로 옷의 개수를 보고 조합의 수를 구한다.

 

5. Github

https://github.com/iihye/Algorithm/blob/main/Programmers/spy_camouflage.py

 

GitHub - iihye/Algorithm

Contribute to iihye/Algorithm development by creating an account on GitHub.

github.com

 

728x90
Comments