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

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

728x90

반응형

Programmers LV2. 위장

문제 설명

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

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

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

스파이가 가진 의상들이 담긴 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

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 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

반응형

from http://yuja-kong.tistory.com/185 by ccl(A) rewrite - 2021-11-23 21:28:15