배열의 원소만큼 추가하기
아무 원소도 들어있지 않은 빈 배열 X가 있습니다. 양의 정수 배열 arr가 매개변수로 주어질 때, arr의 앞에서부터 차례대로 원소를 보면서 원소가 a라면 X의 맨 뒤에 a를 a번 추가하는 일을 반복한 뒤의 배열 X를 return 하는 solution 함수를 작성해 주세요.
1 ≤ arr의 길이 ≤ 100
1 ≤ arr의 원소 ≤ 100
📌 사전 학습
Arrays.fill() 은 특정 배열에 시작 인덱스 ~ 종료 인덱스 까지 특정 값을 넣을 수 있는 메서드이다.Arrays.fill(배열, 시작인덱스, 종료인덱스, 넣을 값) 으로 사용해줄 수 있다.💻 풀이
Arrays.fill() 메서드를 이용해 배열의 특정 인덱스에 있는 값을 넣어준다.⌛ 시간 0.03ms ~ 0.19ms
public int[] solution1(int[] arr) {
int count = 0;
for(int num : arr) {
count += num;
}
int[] numArr = new int[count];
int j = 0;
for(int i = 0; i < arr.length; i++) {
Arrays.fill(numArr, j, arr[i] + j, arr[i]);
j += arr[i];
}
return numArr;
}
💻 풀이
List 를 선언해 준다.toArray() 를 이용해 배열로 변환해 return해준다.⌛ 시간 2.73ms ~ 4.91ms
public int[] solution(int[] arr) {
List<Integer> list = new ArrayList<>();
for(int i = 0; i < arr.length; i++) {
for(int j = 0; j < arr[i]; j++) {
list.add(arr[i]);
}
}
return list.stream().mapToInt(i -> i).toArray();
}