의상.python

Haks.·2024년 12월 30일
0

Study

목록 보기
33/65

문제 설명

코니는 매일 다른 옷을 조합하여 입는것을 좋아합니다.

예를 들어 코니가 가진 옷이 아래와 같고, 오늘 코니가 동그란 안경, 긴 코트, 파란색 티셔츠를 입었다면 다음날은 청바지를 추가로 입거나 동그란 안경 대신 검정 선글라스를 착용하거나 해야합니다.

종류 이름
얼굴 동그란 안경, 검정 선글라스
상의 파란색 티셔츠
하의 청바지
겉옷 긴 코트
코니는 각 종류별로 최대 1가지 의상만 착용할 수 있습니다. 예를 들어 위 예시의 경우 동그란 안경과 검정 선글라스를 동시에 착용할 수는 없습니다.
착용한 의상의 일부가 겹치더라도, 다른 의상이 겹치지 않거나, 혹은 의상을 추가로 더 착용한 경우에는 서로 다른 방법으로 옷을 착용한 것으로 계산합니다.
코니는 하루에 최소 한 개의 의상은 입습니다.
코니가 가진 의상들이 담긴 2차원 배열 clothes가 주어질 때 서로 다른 옷의 조합의 수를 return 하도록 solution 함수를 작성해주세요.

제한사항
clothes의 각 행은 [의상의 이름, 의상의 종류]로 이루어져 있습니다.
코니가 가진 의상의 수는 1개 이상 30개 이하입니다.
같은 이름을 가진 의상은 존재하지 않습니다.
clothes의 모든 원소는 문자열로 이루어져 있습니다.
모든 문자열의 길이는 1 이상 20 이하인 자연수이고 알파벳 소문자 또는 '_' 로만 이루어져 있습니다.

입출력 예
clothes																						return
[["yellow_hat", "headgear"], ["blue_sunglasses", "eyewear"], ["green_turban", "headgear"]]	5
[["crow_mask", "face"], ["blue_sunglasses", "face"], ["smoky_makeup", "face"]]				3

풀이

def solution(clothes):
    # 의류 종류별 개수를 저장할 딕셔너리
    cloth_dict = {}

    # 의류 종류별 개수 세기
    for _, kind in clothes:
        if kind not in cloth_dict:
            cloth_dict[kind] = 0
        cloth_dict[kind] += 1

    # 모든 경우의 수 계산
    mul = 1
    for count in cloth_dict.values():
        mul *= (count + 1)  # 해당 종류를 입지 않는 경우 포함

    # 아무것도 입지 않는 경우 제외
    return mul - 1

# Counter 함수 사용
from collections import Counter
def solution(clothes) :
	
	cloth_dict = Counter([kind for _, kind in clothes])
	
	answer = 1
	for count in cloth_dict.values():
		answer *= (count + 1)
		
		return answer - 1

reduce 모듈

from collections import Counter
from functools import reduce

def solution(clothes) :
	cnt = Counter([kind for name, kind in clothes])
    asnwer = reduce(lambda x, y : x * (y+1), cnt values(), 1) -1
    return answer
  • reduce 매서드는 리스트나, 딕셔너리 형태에서 하나씩 제거하면서 사용하는 함수이다.
    마지막 1은 초기값이다, 초기값을 1로 주지 않으면 첫 값에서 +1 이 들어가지 않는다 그래서 초기값을 1로 설정하여 처음 항부터 계산식을 적용시키는 것이다.

0개의 댓글

관련 채용 정보