문제 설명
이차원 정수 배열 arr이 매개변수로 주어집니다. arr의 행의 수가 더 많다면 열의 수가 행의 수와 같아지도록 각 행의 끝에 0을 추가하고, 열의 수가 더 많다면 행의 수가 열의 수와 같아지도록 각 열의 끝에 0을 추가한 이차원 배열을 return 하는 solution 함수를 작성해 주세요.
제한사항
- 1 ≤ arr의 길이 ≤ 100
- 1 ≤ arr의 원소의 길이 ≤ 100
- arr의 모든 원소의 길이는 같습니다.
- 1 ≤ arr의 원소의 원소 ≤ 1,000
입출력 예
arr | result |
[[572, 22, 37], [287, 726, 384], [85, 137, 292], [487, 13, 876]] | [[572, 22, 37, 0], [287, 726, 384, 0], [85, 137, 292, 0], [487, 13, 876, 0]] |
[[57, 192, 534, 2], [9, 345, 192, 999]] | [[57, 192, 534, 2], [9, 345, 192, 999], [0, 0, 0, 0], [0, 0, 0, 0]] |
[[1, 2], [3, 4]] | [[1, 2], [3, 4]] |
입출력 예 설명
입출력 예 #1
- 예제 1번의 arr은 행의 수가 4, 열의 수가 3입니다. 행의 수가 더 많으므로 열의 수를 4로 만들기 위해 arr의 각 행의 끝에 0을 추가한 이차원 배열 [[572, 22, 37, 0], [287, 726, 384, 0], [85, 137, 292, 0], [487, 13, 876, 0]]를 return 합니다.
입출력 예 #2
- 예제 2번의 arr은 행의 수가 2, 열의 수가 4입니다. 열의 수가 더 많으므로 행의 수를 4로 만들기 위해 arr의 각 열의 끝에 0을 추가한 이차원 배열 [[57, 192, 534, 2], [9, 345, 192, 999], [0, 0, 0, 0], [0, 0, 0, 0]]을 return 합니다.
입출력 예 #3
- 예제 3번의 arr은 행의 수와 열의 수가 2로 같습니다. 따라서 0을 추가하지 않고 [[1, 2], [3, 4]]을 return 합니다.
function solution(arr) {
const row = arr.length;
const col = arr[0].length;
const gap = Math.abs(row - col)
// 열과 행이 같음
if (gap === 0) return arr
// 행이 더 많다
if (row > col) {
const temp = new Array(gap).fill(0)
return arr.map((el) => [...el, ...temp])
}
// 열이 더 많다
if (row < col) {
const temp = new Array(arr[0].length).fill(0)
for (let i = 0; i < gap; i++){
arr.push(temp)
}
return arr
}
}
https://school.programmers.co.kr/learn/courses/30/lessons/181830
'study > Algorithm' 카테고리의 다른 글
[프로그래머스] 그림 확대 (0) | 2024.07.03 |
---|---|
[프로그래머스] 옹알이 (1) (1) | 2024.07.02 |
[프로그래머스] 무작위로 K개의 수 뽑기 (0) | 2024.05.28 |
[프로그래머스] 배열 만들기 2 (0) | 2024.05.20 |
[프로그래머스] 수열과 구간 쿼리 2 (0) | 2024.05.09 |