-
[백준/BOJ] 2903번 : 중앙 이동 알고리즘 (JAVA / 자바)백준 2022. 2. 2. 21:15
안녕하세요~ 코딩하는 코알못 코메인입니다.
https://www.acmicpc.net/problem/2903
- 문제 -
난이도 브론즈 3 문제이다.
자바에서 입력방식은 scanner와 bufferedreader가 있다.
자바를 초반에 접하면 처음에 배우는 입력은 scanner이다. scanner가 bufferedreader보다 편하지만 속도가 느리다.
bufferedreader는 무조건 문자열로 받아오기때문에 정수형이나 실수형 변수에 저장하기 위해서는 입력과 형변환을 해줘야한다.
더 자세한 내용은 아래 글 참고 하면 좋다.
풀이 방법
패턴을 우선 보면 모든 점의 수는 한변의 점의 제곱이다. 점의 갯수는 늘어날때마다 현재 점의 -1만큼 늘어난다.
처음에 2개였던 점이 다음에 2+(2-1)가 되어서 3이 되고, 다음엔 3+(3-1) = 5, 또 다음엔 5+(5-1) = 9 이렇게 늘어난다. 그렇다면 반복문으로 입력값만큼 한 변의 점의 갯수를 늘리고 그 갯수를 제곱해서 출력한다.
-풀이-
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; 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()); int d = 2; for(int i = 0; i < N; i++) { d += (d - 1); } System.out.println(d * d); } }
-결과-
아직 코딩 공부가 부족한 필자라 설명과 풀이 방법이 많이 미흡할 수 있다. 코딩 고수들은 보시고 문제점이 있다면 댓글로 말해주시면 감사한 마음으로 참고 수정 하겠다.
'백준' 카테고리의 다른 글
[백준/BOJ] 2935번 : 소음 (JAVA / 자바) (0) 2022.02.02 [백준/BOJ] 2921번 : 도미노 (JAVA / 자바) (0) 2022.02.02 [백준/BOJ] 2884번 : 알람 시계 (JAVA / 자바) (0) 2022.02.02 [백준/BOJ] 2721번 : 삼각수의 합 (JAVA / 자바) (0) 2022.02.01 [백준/BOJ] 2783번 : 삼각 김밥 (JAVA / 자바) (0) 2022.02.01