-
[백준/BOJ] 2164번 : 카드2 (JAVA / 자바)백준 2022. 2. 28. 17:50
안녕하세요~ 코딩하는 코알못 코메인입니다.
https://www.acmicpc.net/problem/2164
- 문제 -
난이도 브론즈 3 문제이다.
자바에서 입력방식은 scanner와 bufferedreader가 있다.
자바를 초반에 접하면 처음에 배우는 입력은 scanner이다. scanner가 bufferedreader보다 편하지만 속도가 느리다.
bufferedreader는 무조건 문자열로 받아오기때문에 정수형이나 실수형 변수에 저장하기 위해서는 입력과 형변환을 해줘야한다.
더 자세한 내용은 아래 글 참고 하면 좋다.
풀이 방법
맨 앞 값을 제거하고, 제거한 뒤 맨 앞 값을 맨 뒤로 보낸다. 이것만봐도 큐를 사용해 풀라는 것을 알겠다.
큐를 사용할 줄 안다면 쉽다.
입력값 N.
1~N까지의 값을 순서대로 큐에 저장한다. 맨 앞에 위치한 값부터 제거해주고, 그 다음 값을 뒤로 보내준다. 이 동작을 큐에 하나만 남을때까지 반복해준다.
코드를 보자.
-풀이-
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.LinkedList; import java.util.Queue; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); int N = Integer.parseInt(br.readLine()); Queue<Integer> que = new LinkedList<Integer>(); for(int i = 1; i <= N; i++) { que.offer(i); } while(que.size() > 1) { que.poll(); que.offer(que.poll()); } System.out.println(que.peek()); } }
-결과-
아직 코딩 공부가 부족한 필자라 설명과 풀이 방법이 많이 미흡할 수 있다. 코딩 고수분들은 보시고 문제점이 있다면 댓글로 말해주시면 감사한 마음으로 참고 수정 하겠습니다.
'백준' 카테고리의 다른 글
[백준/BOJ] 2292번 : 벌집 (JAVA / 자바) (0) 2022.02.28 [백준/BOJ] 2231번 : 분해합 (JAVA / 자바) (0) 2022.02.28 [백준/BOJ] 2108번 : 통계학 (JAVA / 자바) (2) 2022.02.27 [백준/BOJ] 1978번 : 소수 찾기 (JAVA / 자바) (0) 2022.02.27 [백준/BOJ] 1966번 : 프린터 큐 (JAVA / 자바) (0) 2022.02.27