[Java] 제일 작은 수 제거하기

최서영·2024년 10월 11일

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

<제한 조건>
arr은 길이 1 이상인 배열입니다.
인덱스 i, j에 대해 i ≠ j이면 arr[i] ≠ arr[j] 입니다.

<입출력 예>

arrreturn
[4,3,2,1][4,3,2]
[10][-1]

<풀이>

import java.util.*;

public class Solution {
    public int[] solution(int[] arr) {
        // 배열의 길이가 1이면 [-1]을 반환
        if (arr.length == 1) {
            return new int[] {-1};
        }

        // 가장 작은 수 찾기
        int min = Arrays.stream(arr).min().getAsInt();

        // 가장 작은 수를 제외한 새 배열 생성
        return Arrays.stream(arr).filter(num -> num != min).toArray();
            
            // min 값 제외하고 배열로 변환               
    }
}

1. int min = Arrays.stream(arr).min().getAsInt();

  • Arrays.stream(arr)은 배열 arr를 스트림으로 변환한다.
  • min() 메소드를 이용해 배열 내의 최소값을 찾는다.
  • getAsInt()는 찾은 최소값을 int 타입으로 반환한다.

2. Arrays.stream(arr).filter(num -> num != min).toArray();

  • filter() 메소드를 사용하여 배열 arr에서 최소값인 min을 제외한 새로운 스트림을 생성한다.
  • toArray()를 사용하여 스트림을 배열로 변환한다..

0개의 댓글