반응형
문제
동호는 내년에 초등학교를 입학한다. 그래서 동호 어머니는 수학 선행 학습을 위해 쉽게 푸는 문제를 동호에게 주었다.
이 문제는 다음과 같다. 1을 한 번, 2를 두 번, 3을 세 번, 이런 식으로 1 2 2 3 3 3 4 4 4 4 5.. 이러한 수열을 만들고 어느 일정한 구간을 주면 그 구간의 합을 구하는 것이다.
하지만 동호는 현재 더 어려운 문제를 푸느라 바쁘기에 우리가 동호를 도와주자.
입력
첫째 줄에 구간의 시작과 끝을 나타내는 정수 A, B(1 ≤ A ≤ B ≤ 1,000)가 주어진다. 즉, 수열에서 A번째 숫자부터 B번째 숫자까지 합을 구하면 된다.
출력
첫 줄에 구간에 속하는 숫자의 합을 출력한다.
테스트 케이스
입력 1
1 1000
출력 1
29820
입력 2
1 1
출력 2
1
입력 3
3 100
출력 3
942
접근
1.숫자 두 개를 입력받습니다.
1-1. 하나는 시작 지점, 하나는 끝 지점
2. 시작 지점부터 끝까지 지점까지 수열의 합을 구하는 문제입니다.
수열을 먼저 채워줘야 되는데, 1은 한 개 2는 2개 3은 3개 4는 4개 식으로 입력받은 끝 지점까지만 채워주면 됩니다.
그 후, 입력된 수열을 가지고 index를 이용해 원하는 지점 합을 구하여 출력하니 문제가 해결되었습니다.
코드
import java.awt.desktop.SystemEventListener;
import java.io.*;
import java.math.*;
import java.util.*;
public class Main {
/*
1292 problem
*/
public static void main(String[] args) throws NumberFormatException, IOException {
// TODO Auto-generated method stub
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
StringTokenizer st = new StringTokenizer(br.readLine());
ArrayList<Integer> list = new ArrayList<>();
int start = Integer.parseInt(st.nextToken());
int end = Integer.parseInt(st.nextToken());
int count = 1;
int result = 0;
//값 집어넣기
for(int i=0; i<end; i++) {
for(int j=0; j<count; j++) {
list.add(count);
}
count++;
}
//특정 값 더하기
for(int i=start; i<=end; i++) {
result += list.get(i-1);
}
//출력
bw.write(String.valueOf(result));
bw.flush();
br.close();
bw.close();
}
}
주의
반응형
'공부 정리 > 백준' 카테고리의 다른 글
[백준] 자바 1920 수 찾기 (0) | 2021.09.09 |
---|---|
[백준] 자바 1789 수들의 합 (0) | 2021.09.08 |
[백준] 자바 2563 색종이 (0) | 2021.09.06 |
[백준] 자바 10610 30 (0) | 2021.09.03 |
[백준] 자바 11004 K번째 수 (0) | 2021.09.02 |
댓글