-
[백준/BOJ] 1964번 : 오각형, 오각형, 오각형… (JAVA / 자바)백준 2022. 1. 29. 18:17
안녕하세요~ 코딩하는 코알못 코메인입니다.
https://www.acmicpc.net/problem/1964
1964번: 오각형, 오각형, 오각형…
첫째 줄에 N(1 ≤ N ≤ 10,000,000)이 주어진다.
www.acmicpc.net
- 문제 -
난이도 브론즈 3 문제이다.
자바에서 입력방식은 scanner와 bufferedreader가 있다.
자바를 초반에 접하면 처음에 배우는 입력은 scanner이다. scanner가 bufferedreader보다 편하지만 속도가 느리다.
bufferedreader는 무조건 문자열로 받아오기때문에 정수형이나 실수형 변수에 저장하기 위해서는 입력과 형변환을 해줘야한다.
더 자세한 내용은 아래 글 참고 하면 좋다.
(JAVA / 자바) Scanner 와 Bufferedreader
안녕하세요~ 코딩하는 코알못 코메인입니다. 이번엔 백준 문제 풀면서 계속 언급될 scanner와 bufferedreader에 대한 간단한 정리를 해볼거다. 자바에서 입력은 scanner와 bufferedreader가 있다. 우선 각자
comain.tistory.com
풀이 방법
오각형을 더 그릴때마다 처음엔 7개에서 점이 3개가 추가되서 늘어난다. 예를 들면 오각형 한개에서 시작하면 점 5개 다음은 7개가 늘어난 12개, 다음은 7개에서 3개 늘어난 10개가 추가되서 22개, 다음은 10개에서 3개가 늘어난 13개가 추가되서 35개 이렇게 늘어난다.
늘어나는 점의 갯수와 총 점의 갯수는 int의 범위를 넘어가기 때문에 long형으로 한다.
출력할때 45678을 나눠주라 했은 출력할때 연산을 해준다.
-풀이-
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()); long dot = 7; long sum = 5; for(int i = 1; i < N; i++) { sum += dot; dot += 3; } System.out.println(sum % 45678); } }
-결과-
아직 코딩 공부가 부족한 필자라 설명과 풀이 방법이 많이 미흡할 수 있다. 코딩 고수들은 보시고 문제점이 있다면 댓글로 말해주시면 감사한 마음으로 참고 수정 하겠다.
'백준' 카테고리의 다른 글
[백준/BOJ] 2010번 : 플러그 (JAVA / 자바) (0) 2022.01.30 [백준/BOJ] 1975번 : Number Game (JAVA / 자바) (0) 2022.01.29 [백준/BOJ] 1864번 : 문어 숫자 (JAVA / 자바) (0) 2022.01.29 [백준/BOJ] 1837번 : 암호제작 (JAVA / 자바) (0) 2022.01.29 [백준/BOJ] 1703번 : 생장점 (JAVA / 자바) (0) 2022.01.29