728x90
https://www.acmicpc.net/problem/2018
메모리: 14,192 KB , 시간: 152 ms
사용 알고리즘: 수학, 두 포인터
728x90
import java.io.BufferedReader;
import java.io.InputStreamReader;
public class Main {
public static void main(String[] args) throws Exception{
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(br.readLine());
// 투포인터
int s = 1, e = 1;
int sum = 1;
int result = 0;
while(e <= N) {
if(sum == N) {
result++;
sum -= s++;
}
else if(sum < N) {
sum += ++e;
}
else {
sum -= s++;
}
}
System.out.println(result);
}
}
728x90
'Problem Solving > BOJ' 카테고리의 다른 글
[백준, BOJ 2037] 문자메시지 (java) (1) | 2024.09.15 |
---|---|
[백준, BOJ 10025] 게으른 백곰 (java) (1) | 2024.09.13 |
[백준, BOJ 3460] 이진수 (java) (0) | 2024.09.12 |
[백준, BOJ 10829] 이진수 변환 (java) (0) | 2024.09.12 |
[백준, BOJ 1267] 핸드폰 요금 (java) (0) | 2024.09.12 |