https://www.acmicpc.net/problem/8393
1. 아이디어
1부터 n까지의 합은 n * (n + 1) / 2 를 활용하면 시간복잡도 O(1)로 해결할 수 있다.
2. 문제풀이
합이 int형 범위 이내이므로 그대로 연산해서 출력하는 방식으로 구현했다.
3. 코드
import java.io.*;
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());
System.out.println(n * (n + 1) / 2);
}
}
4. 후기
'코딩테스트 준비 > 백준' 카테고리의 다른 글
[백준] 10797번 - 10부제 [Java] (1) | 2024.12.12 |
---|---|
[백준] 2753번 - 윤년 [Java] (0) | 2024.12.12 |
[백준] 1158번 - 요세푸스 문제 [Java] (0) | 2024.12.12 |
[백준] 11866번 - 요세푸스 문제 0 [Java] (0) | 2024.12.12 |
[백준] 11721번 - 열 개씩 끊어 출력하기 [Java] (1) | 2024.12.10 |