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

제일 작은 수 제거하기 // ArrayList.remove() 메서드 + 기본 타입 , 래퍼 클래스

열심히 해 2024. 10. 1. 09:18

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

 

 

1 .

import java.util.ArrayList;

class Solution {
    public static int[] solution(int[] arr) {
        if (arr.length==1) {
            return new int[]{-1};
        }

        int min = arr[0];
        for (int i: arr) {
            if (i <= min) {
                min = i;
            }
        }

        ArrayList<Integer> integers = new ArrayList<>();
        for (int j: arr) {
            integers.add(j);
        }
        
        integers.remove(min);

        int[] answer = new int[integers.size()];

        for (int k=0; k<answer.length; k++) {
            answer[k] = integers.get(k);
        }

        return answer;
    }
}

 

설명 :

 

integers.remove(min); 가 잘못되었습니다. 이렇게 하면 인덱스 min  번째의 값이 사라집니다.

 

  • remove(int index): 특정 인덱스에 있는 원소를 제거합니다.
  • remove(Object o): 특정 값을 가진 첫 번째 원소를 제거합니다.

 

따라서 

 

integers.remove(Integer.valueOf(min));  로 바꿔줘야 합니다. Integer.valueOf() 를 사용하면 Integer 객체가 생성됩니다.

 

Integer는 int 값을 감싸서 객체로서 다룰 수 있게 해줍니다. 이렇게 객체로 감싸는 이유는 기본 타입을 객체처럼 다뤄야 할 때가 있기 때문입니다. 예를 들어, 컬렉션(List, Set, Map) 같은 자료구조는 기본 타입을 직접 저장할 수 없고, 참조 타입만 저장할 수 있기 때문에, Integer 같은 객체로 변환해야 합니다.

 

또한 remove() 메서드에서는 첫 번째로 일치하는 원소만 제가된다는 점을 유의해야 합니다.

 

 

2.

더보기
더보기
더보기
import java.util.Arrays;

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

        // 배열에서 가장 작은 값을 찾기
        int min = arr[0];
        for (int i : arr) {
            if (i < min) {
                min = i;
            }
        }

        // 가장 작은 값을 제외한 새로운 배열을 생성
        int[] answer = new int[arr.length - 1];
        int index = 0;
        for (int i : arr) {
            if (i != min) {
                answer[index++] = i;
            }
        }

        return answer;
    }