-
[백준/BOJ] 1764번 : 듣보잡 (JAVA / 자바)백준 2022. 3. 10. 21:13
안녕하세요~ 코딩하는 코알못 코메인입니다.
https://www.acmicpc.net/problem/1764
- 문제 -
난이도 실버 4 문제이다.
자바에서 입력방식은 scanner와 bufferedreader가 있다.
자바를 초반에 접하면 처음에 배우는 입력은 scanner이다. scanner가 bufferedreader보다 편하지만 속도가 느리다.
bufferedreader는 무조건 문자열로 받아오기때문에 정수형이나 실수형 변수에 저장하기 위해서는 입력과 형변환을 해줘야한다.
더 자세한 내용은 아래 글 참고 하면 좋다.
풀이 방법
HashMap과 List로 풀었다.
HashMap에 듣도 못한 사람의 명단을 저장해준다. Key에 이름을 저장하고, value에는 1을 저장해준다.(어떤 값을 저장하든 상관없다.)
듣도 못한 사람의 명단을 다 저장했으면, 보도 못한 사람의 명단을 HashMap과 비교한다.
입력 값이 HashMap에 저장되어 있다면, 그 사람은 듣도보도 못한 듣보잡이기때문에 list에 저장하고, 개수를 저장할 변수 count에 +1을 해준다.
저장 여부는 HashMap.get(key) != null로 체크해준다. 해당 입력값이 저장되어있지 않다면 value에는 null값으로 나오기 때문이다.
듣보잡을 다 구했으면, 출력할때 사전순으로 출력하라 했으니, collections.sort로 정렬해주고 출력한다.
처음엔 듣보잡 개수. 두번째부터 듣보잡들의 이름을 사전 순으로 출력해야한다.
50만개의 값이 나올 수 있기 때문에 StringBuilder로 한번에 출력해준다.
코드를 보자.
-풀이-
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; import java.util.List; import java.util.StringTokenizer; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); StringTokenizer st = new StringTokenizer(br.readLine()); int N = Integer.parseInt(st.nextToken()); int M = Integer.parseInt(st.nextToken()); StringBuilder sb = new StringBuilder(); HashMap<String, Integer> hash = new HashMap<String, Integer>(); List<String> list = new ArrayList<String>(); for(int i = 0; i < N; i++) { hash.put(br.readLine(), 1); } int count = 0; for(int i = 0; i < M; i++) { String input = br.readLine(); if(hash.get(input) != null) { list.add(input); count++; } } //정렬 Collections.sort(list); sb.append(count).append("\n"); for(int i = 0; i < list.size(); i++) { sb.append(list.get(i)).append("\n"); } System.out.println(sb); } }
-결과-
아직 코딩 공부가 부족한 필자라 설명과 풀이 방법이 많이 미흡할 수 있다. 코딩 고수분들은 보시고 문제점이 있다면 댓글로 말해주시면 감사한 마음으로 참고 수정 하겠습니다.
'백준' 카테고리의 다른 글
[백준/BOJ] 11047번 : 동전 0 (JAVA / 자바) (0) 2022.03.12 [백준/BOJ] 5430번 : AC (JAVA / 자바) (0) 2022.03.11 [백준/BOJ] 2812번 : 크게 만들기 (JAVA / 자바) (0) 2022.03.10 [백준/BOJ] 1676번 : 팩토리얼 0의 개수 (JAVA / 자바) (0) 2022.03.08 [백준/BOJ] 1620번 : 나는야 포켓몬 마스터 이다솜 (JAVA / 자바) (0) 2022.03.07