본문 바로가기
Algorithm/백준풀이

[알고리즘 문제풀이] 백준 9375 패션왕 신해빈 / JAVA코드

by 계범 2022. 1. 19.

https://www.acmicpc.net/problem/9375

 

9375번: 패션왕 신해빈

첫 번째 테스트 케이스는 headgear에 해당하는 의상이 hat, turban이며 eyewear에 해당하는 의상이 sunglasses이므로   (hat), (turban), (sunglasses), (hat,sunglasses), (turban,sunglasses)로 총 5가지 이다.

www.acmicpc.net

 

/**
 * 구현 브루트포스 문제
 * 
 * 해시에 의상종류별 개수 저장
 * 
 * 각 의상 종류별 개수+1 을 곱한다음 다 안고른 상태를 빼면 답
 * 
 * 예) headgear = 2, eyewear = 1
 * 3*2 = 6 -1 = 5
 * 
 */

import java.util.*;
import java.io.*;

public class BJ9375_패션왕신해빈 {
    public static void main(String[] args) throws IOException{
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
        StringTokenizer st;
        
        int t = Integer.parseInt(br.readLine());

        // 테스트
        for(int tc = 0; tc <t; tc++){

            // 의상 수
            int n = Integer.parseInt(br.readLine());
            Map<String,Integer> map = new HashMap<>();

            for(int i = 0; i < n; i++){
                st = new StringTokenizer(br.readLine());
                String name = st.nextToken();
                String type = st.nextToken();
                map.put(type,map.getOrDefault(type,0)+1);
            }
            int result = 1;
            //의상 종류별 수
            for(int v : map.values()){
                result *= (v+1);
            }

            if(map.size() == 0){
                bw.write(0 +"\n");
            }else{
                bw.write(result-1 +"\n");
            }
        }
        bw.flush();
        bw.close();
    }
}

댓글