250x250
Notice
Recent Posts
Recent Comments
Link
반응형
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- scanner
- Calendar
- html
- dfs
- 힙덤프
- BFS
- 스프링부트
- 스택
- deque
- date
- sql
- map
- set
- JPA
- Union-find
- javascript
- List
- union_find
- 리소스모니터링
- math
- alter
- string
- 큐
- GC로그수집
- Java
- Properties
- NIO
- priority_queue
- spring boot
- CSS
Archives
- Today
- Total
매일 조금씩
프로그래머스 level1 : 신고결과받기(카카오) - JAVA 본문
728x90
반응형
HashMap, HashSet이 핵심인 문제다.
1. 일반적
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
class Solution {
public int[] solution(String[] id_list, String[] report, int k) {
Map<String, HashSet<String>> reportMemberList = new HashMap<>(); // 멤버별 신고 당한 id
Map<String, Integer> getMailCount = new HashMap<>(); // 멤버별 처리 결과 메일 받은 횟수
// 초기화
for(String id : id_list){
getMailCount.put(id,0);
reportMemberList.put(id, new HashSet<>());
}
// 멤버별로 신고받은 id 저장
for(String rep : report){
String[] checkReport = rep.split(" ");
reportMemberList.get(checkReport[1]).add(checkReport[0]);
}
// 신고 당한 멤버별로 for문
for(String key : reportMemberList.keySet()){
// 해당 멤버를 신고한 아이디들
HashSet<String> reporters = reportMemberList.get(key);
// 신고한 아이디들이 k개 이상이면
if(reporters.size() >= k){
for(String reporter : reporters){
Integer getMail = getMailCount.get(reporter);
getMailCount.put(reporter, getMail + 1);
}
}
}
int[] answer = new int[id_list.length];
for(int i=0; i < answer.length; i++){
answer[i] = getMailCount.get(id_list[i]);
}
return answer;
}
}
2. 스트림으로 다시 풀어보기
728x90
반응형
'알고리즘 > 해시' 카테고리의 다른 글
[C++] 프로그래머스 : 완주하지 못한 선수 (0) | 2021.02.04 |
---|