알고리즘 문제풀이/프로그래머스
[프로그래머스] 제일 작은 수 제거하기 (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};
}
}