IT 성장일기
[Programmers] 2차원으로 만들기 본문
반응형
2차원으로 만들기
문제 설명
정수 배열 num_list와 정수 n이 매개변수로 주어집니다. num_list를 다음 설명과 같이 2차원 배열로 바꿔 return하도록 solution 함수를 완성해주세요.
num_list가 [1, 2, 3, 4, 5, 6, 7, 8] 로 길이가 8이고 n이 2이므로 num_list를 2 * 4 배열로 다음과 같이 변경합니다. 2차원으로 바꿀 때에는 num_list의 원소들을 앞에서부터 n개씩 나눠 2차원 배열로 변경합니다.
제한사항
- num_list의 길이는 n의 배 수개입니다.
- 0 ≤ num_list의 길이 ≤ 150
- 2 ≤ n < num_list의 길이
내 그지같은 풀이
function solution(num_list, n) {
if ( !validListDividedByNumber(num_list, n) ) {
console.error('배열의 길이와 정수가 나누어 떨어지지 않습니다.');
return false;
}
if ( !validLengthOfList(num_list) ) {
console.error('배열의 길이가 올바르지 않습니다.');
return false;
}
if ( !validRangeOfNumber(num_list, n) ) {
console.error('정수의 크기가 올바르지 않습니다.');
return false;
}
return sliceListByNumber(num_list, n);
}
function validListDividedByNumber(num_list, n) {
return (num_list.length % n) === 0
}
function validRangeOfNumber(num_list, n) {
return n >= 2 && n < num_list.length
}
function validLengthOfList(num_list) {
return num_list.length >= 0 && num_list.length <= 150
}
function sliceListByNumber(num_list, n) {
let slicedLists = [];
for ( let i = 0; i < num_list.length / n; i++ ) {
slicedList = num_list.slice( i * n, ( i + 1 ) * n );
slicedLists.push( slicedList );
}
return slicedLists;
}
import java.util.Arrays;
class Solution {
public int[][] solution(int[] num_list, int n) {
int[][] answer = new int[num_list.length / n][];
int index = 0;
while(index < (num_list.length / n)) {
answer[index] = Arrays.copyOfRange( num_list, index * n, ( index + 1 ) * n );
index++;
}
return answer;
}
}
고수의 풀이
function solution(num_list, n) {
var answer = [];
while(num_list.length) {
answer.push(num_list.splice(0,n));
}
return answer;
}
splice() : 기존 요소를 삭제하거나 교체하여 배열의 내용을 변경하며, 제거된 요소가 담긴 별도의 배열을 새로 반환.
while문이 동작하는 동안 splice() 함수를 이용하여 기존 배열에서 원하는 범위만큼 떼어내고 이를 answer에 담음.
반응형
'Algorithm > Programmers' 카테고리의 다른 글
[Programmers] 종이 자르기 (0) | 2025.02.12 |
---|---|
[Programmers] 나머지가 1이 되는 수 찾기 (0) | 2025.02.12 |
[Programmers] 직사각형 나머지 좌표 구하기 (0) | 2023.09.04 |