알고리즘 문제풀이/프로그래머스

[프로그래머스] 제일 작은 수 제거하기 (lv.1)

du0422 2020. 7. 24. 15:40

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

 

코딩테스트 연습 - 제일 작은 수 제거하기

정수를 저장한 배열, arr 에서 가장 작은 수를 제거한 배열을 리턴하는 함수, solution을 완성해주세요. 단, 리턴하려는 배열이 빈 배열인 경우엔 배열에 -1을 채워 리턴하세요. 예를들어 arr이 [4,3,2,1

programmers.co.kr

 

[문제 풀이]

 

1. 주어진 배열에서 가장 작은 수의 인덱스를 구한다.

2. 새로운 배열을 만들어 해당 수를 빼고 만든다.

3. 새 배열의 길이가 0인 경우 (주어진 배열의 길이가 1인 경우) {-1}을 반환하고 길이가 0이 아니라면 새 배열을 반환한다.

 

[소스 코드]

 

import java.util.Arrays;

public class RemoveTheSmallestNumber {
    public static void main(String[] args) {
        int[] arr = {3, 1, 2, 4};

        System.out.println(Arrays.toString(solution(arr)));
    }

    private static int[] solution(int[] arr) {
        int[] answer = new int[arr.length - 1];

        int minValueIndex = 0;

        for (int i = 0; i < arr.length; i++) {
            if (arr[minValueIndex] > arr[i]) {
                minValueIndex = i;
            }
        }

        for (int i = 0, index = 0; i < arr.length; i++, index++) {
            if (i == minValueIndex) {
                index--;
                continue;
            }
            answer[index] = arr[i];
        }

        return answer.length != 0 ? answer : new int[]{-1};
    }
}