자바 백준 9375번 패션왕 신해빈


 이 문제는 공식을 먼저 찾아야 쉽게 풀 수 있는 문제라고 생각한다.

그리고 같은 이름을 가진 의상이 존재하지 않는다는 조건에서 의상의 이름은 문제를 푸는데 없어도 된다는 점을 잘 파악하여야한다. 즉, 의상의 종류만으로 문제를 풀 수 있다는 것이다.

 다음은 그 공식을 표로 나타낸 그림이다.


                             여기서 공식을 찾을 수 있다. 공식 = (같은 종류의 의상 수 +1)*(같은 종류의 의상 수 +1) *....... *(같은 종류의 의상 수 +1)-1

 

같은 종류의 의상이 들어오면 HashMap을 이용해 그에 해당하는 키값의 value값을 1씩 증가시키고 새로운 의상이 들어오면 그에 해당하는 키값의 value값에 새로운 숫자 1을 넣는다. 이것을 Map 내장 메소드 HashMap.values()를 사용하여 모든 키값의 value 값을 불러와 위와 같은 공식으로 계산하면 된다.



Map 컬렉션(Map<K, V>)

  Map 컬렉션은 (key)와 값(value)으로 구성된 객체를 저장하는 구조를 갖는다키는 중복으로 저장할 수 없고 값은 중복으로 저장할 수 있다.(동일한 key로 값을 추가하면 기존 key에 해당하는 값은 제거된다.) 따라서 Map 컬렉션은 (key)로 데이터를 관리한다. Map 컬렉션을 구현하는 대표적인 클래스들은 HashMap, Hashtable, LinkedHashMap, TreeMap 등이 있다. 공통적으로 사용되는 주요 메서드들은 put, get, remove, keySet 등이 있다.



 K와 V는 제네릭으로 K는 key 타입, V는 value 타입을 의미한다K와 V는 기본 자료형(int, double, boolean )은 사용할 수 없고 클래스나 인터페이스 타입만 사용이 가능하다.
 Map에 저장된 값을 가져오기 위해서는 get 메서드로 key 값을 입력하여 하나씩 가져오거나, keySet 및 entrySet 메서드를 이용하여 Set 컬렉션에 key 및 value를 저장하여 반복문을 통해 가져올 수 있다. 해당 내용에 대한 예제는 구현 클래스에서 알아보도록 하겠다.

HashMap

 HashMap은 Map 컬렉션의 대표적인 구현 클래스이다. HashMap을 생성하는 방법은 아래와 같다.



예제를 통해서 HashMap을 사용하는 방법에 대해서 간단히 알아보자.

import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.Set; public class HashMapEx01 { public static void main(String[] args) { // key는 String 타입으로, value는 Integer 타입으로 지정 Map<String, Integer> hm = new HashMap<String, Integer>(); // put 메서드 이용 key와 value 추가 hm.put("A", 90); hm.put("B", 80); hm.put("C", 80); hm.put("D", 60); // size 메서드 이용 저장된 객체 수 출력 System.out.println("저장된 객체 수 : " + hm.size()); // get 메서드로 특정 key에 해당하는 값 출력 System.out.println("D의 값 : " + hm.get("D")); // 동일한 key로 추가(기존 내용 삭제) hm.put("C", 70); System.out.println("-------------------"); // keySet 메서드 이용 저장된 모든 key 값을 Set 컬렉션에 저장 Set<String> keys = hm.keySet(); // 반복자 생성 Iterator<String> it = keys.iterator(); while (it.hasNext()) { String key = it.next(); // Set의 key 값을 하나씩 key에 대입 int value = hm.get(key); // 해당 key에 해당하는 value 대입 / 오토 언박싱 System.out.println(key + " : " + value); } } }

 설명은 예제의 주석 부분을 참고하면 된다.

Hashtable

 Hashtable은 HashMap과 동일한 사용법을 갖는다. 차이점은 Hashtable은 동기화(synchronization)를 보장한다. 따라서 멀티 스레드에서는 Hashtable을 사용해야 하고, 단일 스레드에서는 HashMap을 사용하는 게 유리하다. Hashtable을 생성하는 방법은 아래와 같다.



 이번에는 Hashtable을 생성하고 entrySet 메서드를 이용하여 데이터를 출력하는 방법을 알아보자.

import java.util.Hashtable; import java.util.Iterator; import java.util.Map; import java.util.Map.Entry; import java.util.Set; public class HashtableEx01 { public static void main(String[] args) { Map<String, String> ht = new Hashtable<String, String>(); // key와 value값 저장 ht.put("사과", "Apple"); ht.put("복숭아", "Peach"); ht.put("망고스틴", "Mangosteen"); ht.put("석류", "Poemegranate"); ht.put("딸기", "Strawberries"); // entrySet 메서드 이용 Set 컬렉션에 key와 value 저장 Set<Entry<String, String>> fruits = ht.entrySet(); // 반복자 생성 Iterator<Entry<String, String>> it = fruits.iterator(); while (it.hasNext()) { Entry<String, String> entry = it.next(); String key = entry.getKey(); String value = entry.getValue(); System.out.println(key + " : " + value); } } }


+ Recent posts