알고리즘
[알고리즘/Programmers] LV2. 위장 (Java)
자기개발자 유자
2021. 11. 23. 21:17
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
- ((의상 종류의 가짓 수 + 안입을 경우 1) * (의상 종류의 가짓수 + 안입을 경우 1) ...) - 전체를 안입은 경우 1
- 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
반응형