티스토리 뷰

알고리즘

알고리즘)[JAVA] HashMap

Henry95 2020. 2. 6. 12:36
반응형

Map<String, Integer> m = new HashMap<>();
Hashtable<String, Integer> ht = new Hashtable<String, Integer>();
HashMap<String, Integer> hm = new HashMap<>();

 

선언은 위와같이함

해시맵 이외에 해시테이블과 맵또한 넣어놓음

 

기본적으로


hm.put(key(String)값, value(Integer)값);
//위처럼 값을 집어넣고

hm.get(key값)
//위처럼 key에 해당하는 value를얻어옴

 

유용한 함수로는 getOrDefault()

 


hm.getOrDefault(key, Default-value);

 

위와같이 사용하는데 원하는 key에 해당하는 value가 존재하지 않을경우 default값을 return시킨다.

 

또다른 함수로는 putIfAbsent();


hm.putIfAbsent(key, value);

 

key가 이미 value와 매핑되어있을경우 매핑되지 않는다.

예를들면 


hm.putIfAbsent("first", 1);
hm.putIfAbsent("first", 2);
//같은 key값에 두번 value를 집어넣음

 

위와 같은경우 first에대한 value는 1이 된다.

 

해시 key 탐색하는방법

 

hashmap은 array와같이 인덱스가 정해져있지않다. 이런경우 아래와 같은 방법을 통해 순차탐색을 가능하게한다.


Set set = hm.keySet();
Iterator iterator = set.iterator();

while(iterator.hasNext()){
  String key = (String)iterator.next();
  System.out.println("hashMap Key : " + key);
}

 

해시 value를 탐색하는 방법

 

위와 같은 방식을 사용하다가 hm.get(key)로 value를 구해도 상관은없지만 다른방법이 있다.

 


Set set = hm.entrySet();
Iterator iterator = set.iterator();

while(iterator.hasNext()){
  Map.Entry entry = (Map.Entry)iterator.next();
  String key = (String)entry.getKey();
  String value = (String)entry.getValue();
  System.out.println("hashMap Key : " + key);
  System.out.println("hashMap Value : " + value);
}

 

위처럼 keySet()이 아닌 entrySet()을 사용해서  key와 value를 동시에 구할수 있다.

반응형
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/05   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함