[백준] 자바 1292 쉽게 푸는 문제

[백준] 자바 1292 쉽게 푸는 문제

문제

동호는 내년에 초등학교를 입학한다. 그래서 동호 어머니는 수학 선행 학습을 위해 쉽게 푸는 문제를 동호에게 주었다.

이 문제는 다음과 같다. 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 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

주의

728x90

반응형

from http://kjs-dev.tistory.com/122 by ccl(A) rewrite - 2021-09-07 10:26:58