본문 바로가기
Algorithm

[알고리즘] 프로그래머스(Level1) - x만큼 간격이 있는 n개의 숫자(Java)

by 가영리 2022. 6. 6.
728x90

https://programmers.co.kr/learn/courses/30/lessons/12954

 

코딩테스트 연습 - x만큼 간격이 있는 n개의 숫자

함수 solution은 정수 x와 자연수 n을 입력 받아, x부터 시작해 x씩 증가하는 숫자를 n개 지니는 리스트를 리턴해야 합니다. 다음 제한 조건을 보고, 조건을 만족하는 함수, solution을 완성해주세요.

programmers.co.kr

 

 

문제 설명
  • 함수 solution은 정수 x와 자연수 n을 입력 받아, x부터 시작해 x씩 증가하는 숫자를 n개 지니는 리스트를 리턴해야 합니다.
  • 다음 제한 조건을 보고, 조건을 만족하는 함수, solution을 완성해주세요.

 

제한 조건
  • x는 -10000000이상 10000000 이하인 정수입니다.
  • n은 1000이하인 자연수입니다.

 

입출력 예

 

x n answer
2 5 [2,4,6,8,10]
4 3 [4,8,12]
-4 2 [-4,-8]

 

풀이
class Solution {
    public long[] solution(int x, int n) {
        long[] answer = new long[n]; 1️⃣
        answer[0] = x; 2️⃣

        for(int i=1; i<n; i++){ 3️
            answer[i] = answer[i-1] + x; 3️⃣
        }
        return answer; 
    }
}

 

1️⃣ - 숫자 n개를 지니는 리스트 생성

2️⃣ - 정수 x부터 시작하는 리스트이므로 0번째 원소의 값을 x로 갱신

3️⃣ - x씩 증가

 

실행 코드
class Solution{
	public long[] solution(int x, int n) {
		long[] answer = new long[n];
		answer[0] = x;
		
		for(int i=1; i<n; i++)
		{
			answer[i] = answer[i-1] + x;
		}
		
		return answer;
	}
}
public class Main {

	public static void main(String[] args) {
		
		Scanner sc = new Scanner(System.in);
		
		int x = sc.nextInt();
		int n = sc.nextInt();
		
		Solution sol = new Solution();
		
		long[] answer = new long[n];
		
		answer = sol.solution(x, n);
		
		System.out.println(Arrays.toString(answer));
	}

}

 

왜 리스트의 데이터 타입을 int가 아닌 long으로 했을까?

 

  • int 는 4byte로 -217483648 ~ 217483648 까지 표현이 가능하다.
  • long은 8byte로 -9223372036854775808 ~ 9223372036854775808 까지 표현이 가능하다.

x = 10000000, n = 1000일 때 리스트 원소의 값이 217483648 이상인 상황이 발생한다.  

따라서 더 큰 범위를 표현 가능한 long형으로 데이터 타입을 선언하는 것이 적절하다.