본문 바로가기

알고리즘

[알고리즘/Programmers] LV2. 위장 (Java)

728x90
반응형
Programmers LV2. 위장

 

문제 설명

스파이들은 매일 다른 옷을 조합하여 입어 자신을 위장합니다.

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

종류 이름
얼굴 동그란 안경, 검정 선글라스
상의 파란색 티셔츠
하의 청바지
겉옷 긴 코트

스파이가 가진 의상들이 담긴 2차원 배열 clothes가 주어질 때 서로 다른 옷의 조합의 수를 return 하도록 solution 함수를 작성해주세요.

 

제한 사항

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

 

입출력 예

clothes return
[["yellowhat", "headgear"], ["bluesunglasses", "eyewear"], ["green_turban", "headgear"]] 5
[["crowmask", "face"], ["bluesunglasses", "face"], ["smoky_makeup", "face"]] 3

 

728x90

 

해결 방법

  • 경우의 수 구하는 공식을 캐치해야 한다.
    • ((의상 종류의 가짓 수 + 안입을 경우 1) * (의상 종류의 가짓수 + 안입을 경우 1) ...) - 전체를 안입은 경우 1
      = 총 경우의 수
      ex) headgear의 가짓 수 : 2 / eyewears의 가짓 수 : 1
      ((2+1) * (1+1)) -1 = 5
  • hashMap의 key 기준 카운트를 세어 가짓 수 파악하고 공식을 적용한다.
    이 때 hashMap의 getKeyOrDefault() 을 이용할 수 있다.
반응형

코드

package programmers.level2;
import java.util.HashMap;

/*
    위장
 */
public class test_42578 {
    public static void main(String[] args) {
        String[][] clothes = {
                {"yellowhat", "headgear"},
                {"bluesunglasses", "eyewear"},
                {"green_turban", "headgear"}
        };
        System.out.println(solution(clothes));
    }
    static public int solution(String[][] clothes) {
        int answer = 1;

        HashMap<String, Integer> hm = new HashMap<>();
        for(String[] c : clothes) {
            hm.put(c[1], hm.getOrDefault(c[1], 0) + 1);
        }
        for(String key : hm.keySet()) {
            answer *= (hm.get(key)+1);
        }
        answer -= 1;

        return answer;
    }
}

 



처음에 봤을 때 조합을 어떻게 풀어나가지 막막했는데 풀이 이해하니까 어렵지 않은 문제였다. 이런 문제 스타일을 잘 캐치하도록 기억해야겠다.

728x90
반응형