본문 바로가기

코딩테스트/프로그래머스

[프로그래머스][JAVA] x만큼 간격이 있는 n개의 숫자 (LV.1)

728x90
반응형

 문제 설명

함수 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];
        int cnt = 0;
        
        if(x == 0) {
            for(int i=0; i<answer.length; i++) {
                answer[i] = (long) x;
            }
        } else if(x < 0) {
            for(long i=x; i>=(long) x*n; i+=(long) x) {
                answer[cnt++] = i;
            }
        } else {
            for(long i=x; i<=(long) x*n; i+=(long) x) {
                answer[cnt++] = i;
            }
        }
        
        return answer;
    }
}

 

다른 사람의 풀이
import java.util.*;
class Solution {
    public static 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;

    }
}
728x90
반응형