on
[알고리즘/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