본문 바로가기
공부 정리/백준

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

by 경적필패. 2021. 9. 7.
반응형

문제

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

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

댓글