새소식

Programmers Coding Test/Java

[프로그래머스 120809] Java - 코딩테스트 입문 / 배열 두 배 만들기

  • -

 

 

배열 두 배 만들기

 

 

 

https://school.programmers.co.kr/learn/courses/30/lessons/120809

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

 

 

 

1)  문제

정수 배열 numbers가 매개변수로 주어집니다.
numbers의 각 원소에 두배한 원소를 가진 배열을 return하도록 solution 함수를 완성해주세요.
제한사항
-10,000 ≤ numbers의 원소 ≤ 10,000
1 ≤ numbers의 길이 ≤ 1,000

 

 

 

2)  예시

 

 

Result Table
numbers result
[1, 2, 3, 4, 5] [2, 4, 6, 8, 10]
[1, 2, 100, -99, 1, 2, 3] [2, 4, 200, -198, 2, 4, 6]

 

 

 

입출력 예 #1
[1, 2, 3, 4, 5]의 각 원소에 두배를 한 배열 [2, 4, 6, 8, 10]을 return합니다.


입출력 예 #2
[1, 2, 100, -99, 1, 2, 3]의 각 원소에 두배를 한 배열 [2, 4, 200, -198, 2, 4, 6]을 return합니다.

 

 

 

 

3)  풀이

 

 

1. 클래스 선언을 해줍니다

● class Solution {

클래스명은 대문자로 시작해야하고, 정답이라는 의미로 Solution이라는 단어를 사용하였습니다.

 

 

 

 

2. 메소드 선언을 해줍니다.

● public int[] solution(int[] numbers) {

정수배열 numbers를 매개변수로 사용하는 solution 메소드를 선언해줍니다.

메소드의 결과값인 solution은 정수배열로 나오므로, 데이터 타입을 int[]로 해줍니다.

 

 

 

 

3. numbers의 두배 값이 담기는 answer 배열을 선언해줍니다.

배열의 크기는 numbers.length값과 동일하게 할당해줍니다.

int[] answer = new int[numbers.length];

 

 

 

 

4. 배열의 길이에 대한 제한사항을 확인하고, 만족하지 않는다면 예외처리합니다.

      if(1> numbers.length || numbers.length > 1000){
            throw new IllegalArgumentException("배열 길이는 1 이상 1000 이하여야합니다");
        }

        

 

 

 

5. 먼저 정수 index를 선언해줍니다. 그 index는 새로운 배열 answer의 인덱스로 사용될 예정입니다.

제한사항에 만족할 경우, for문을 통해 numbers 배열을 순회하면서

numbers 배열의 i번째 인덱스일때 그 값을 2배 해주며, answer 배열의 index 값 0부터 값을 할당해줍니다.  

numbers의 i도 0부터 시작이고, answer 배열의 index도 0부터 시작해서 1씩 증가하니 같이 계속 numbers배열의 길이까지 증가할 것입니다.

이렇게 모든 순회가 끝난 값인 answer을 반환해줍니다.

      int index = 0;

        for(int i = 0; i < array.length; i++){
        if(1<= array[i] && array[i]<=200 && array[i] > height){
            result++;
            }

        }
      return result;
    }
}

 

 

 

 

 

 

4)  코드

 

class Solution {
    public int[] solution(int[] numbers) {
        int[] answer = new int[numbers.length];
        
        if(1> numbers.length || numbers.length > 1000){
            throw new IllegalArgumentException("배열 길이는 1 이상 1000 이하여야합니다");
        }
        
        int index = 0;
        
        for(int i=0; i < numbers.length; i++){
            if(-10000> numbers[i] || numbers[i] > 10000){
                throw new IllegalArgumentException("배열의 원소 크기 제한을 확인하세요");
            }           
            answer[index++] = numbers[i] * 2;
        
        }
                 
        
        return answer;
    }
}

 

 

 

 

 

 

 

 

 

Contents

포스팅 주소를 복사했습니다

이 글이 도움이 되었다면 공감 부탁드립니다.