새소식

Programmers Coding Test/Java

[프로그래머스 120821] Java - 코딩테스트 입문 / 배열 뒤집기

  • -

 

 

배열 뒤집기

 

 

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

 

프로그래머스

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

programmers.co.kr

 

 

 

1)  문제

정수가 들어 있는 배열 num_list가 매개변수로 주어집니다.
num_list의 원소의 순서를 거꾸로 뒤집은 배열을 return하도록 solution 함수를 완성해주세요.
제한사항
1 ≤ num_list의 길이 ≤ 1,000
0 ≤ num_list의 원소 ≤ 1,000

 

 

 

2)  예시

 

 

Result Table
num_list result
[1, 2, 3, 4, 5] [5, 4, 3, 2, 1]
[1, 1, 1, 1, 1, 2] [2, 1, 1, 1, 1, 1]
[1, 0, 1, 1, 1, 3, 5] [5, 3, 1, 1, 1, 0, 1]

 

 

 

입출력 예 #1
num_list가 [1, 2, 3, 4, 5]이므로 순서를 거꾸로 뒤집은 배열 [5, 4, 3, 2, 1]을 return합니다.


입출력 예 #2
num_list가 [1, 1, 1, 1, 1, 2]이므로 순서를 거꾸로 뒤집은 배열 [2, 1, 1, 1, 1, 1]을 return합니다.


입출력 예 #3
num_list가 [1, 0, 1, 1, 1, 3, 5]이므로 순서를 거꾸로 뒤집은 배열 [5, 3, 1, 1, 1, 0, 1]을 return합니다.

 

 

 

3)  풀이

 

 

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

● class Solution {

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

 

 

 

 

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

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

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

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

 

 

 

 

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

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

 

 

 

 

4. num_list를 뒤집은 새로운 배열을 answer로 선언하고, 그 크기는 num_list.length로 합니다.

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


        

 

 

 

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

먼저 num_list.length -1은 마지막원소를 뜻합니다.

 

그래서 answer[num_list.length - 1 -i] = num_list[i] 를 해주게 된다면 num_list에서 i번째 원소값이 answer의 마지막 원소에서 i번 이전 값이 정해질 수 있게 됩니다. 즉, 이게 배열을 뒤집는 것이죠.

 

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

   for (int i = 0; i < num_list.length; i++) {
            if (0 <= num_list[i] && num_list[i] <= 1000) {
                answer[num_list.length - 1 - i] = num_list[i];
            } else {
                throw new IllegalArgumentException("num_list의 원소는 0 이상 1000 이하여야합니다.");
            }
        }
        return answer;
    }
}

 

 

 

 

 

 

4)  코드

 

class Solution {
    public int[] solution(int[] num_list) {
        if (num_list.length < 1 || num_list.length > 1000) {
            throw new IllegalArgumentException("num_list 길이는 1 이상 1000 이하여야합니다.");
        }

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

        for (int i = 0; i < num_list.length; i++) {
            if (0 <= num_list[i] && num_list[i] <= 1000) {
                answer[num_list.length - 1 - i] = num_list[i];
            } else {
                throw new IllegalArgumentException("num_list의 원소는 0 이상 1000 이하여야합니다.");
            }
        }
        return answer;
    }
}

 

 

 

 

 

 

 

 

 

Contents

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

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