강의로 돌아가기
leegangtoe

js solution

function effect(board, skill) {
    let damage = skill[5];
    if (skill[0] == 1) damage = damage*(-1);
    board[skill[1]][skill[2]] += damage;
    if (skill[4]+1 < board[0].length) board[skill[1]][skill[4]+1] -= damage;
    if (skill[3]+1 < board.length) board[skill[3]+1][skill[2]] -= damage;
    if (skill[4]+1 < board[0].length && skill[3]+1 < board.length) board[skill[3]+1][skill[4]+1] += damage;
}

function solution(board, skill) {
    var answer = 0;
    let aBoard = new Array(board.length).fill(0).map(e => new Array(board[0].length).fill(0))
    for(let i in skill) {
        effect(aBoard,skill[i])
        //console.log(aBoard)
    }

    for(let i=0; i<aBoard.length; i++) {
        for (let j=1; j<aBoard.length; j++) {
            aBoard[i][j] += aBoard[i][j-1]; 
        }
    }

    for(let i=0; i<aBoard.length; i++) {
        for (let j=1; j<aBoard.length; j++) {
            aBoard[j][i] += aBoard[j-1][i]; 
        }
    }

    for(let i=0; i<aBoard.length; i++) {
        for (let j=0; j<aBoard.length; j++) {
            board[i][j] += aBoard[i][j]; 
        }
    }

    for(let i in board) {
        for (let j in board[i]) {
            if(board[i][j] > 0) answer += 1; 
        }
    }
    return answer;
}
작성중인 코드―solution.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
function effect(board, skill) {
    let damage = skill[5];
    if (skill[0] == 1) damage = damage*(-1);
    board[skill[1]][skill[2]] += damage;
    if (skill[4]+1 < board[0].length) board[skill[1]][skill[4]+1] -= damage;
    if (skill[3]+1 < board.length) board[skill[3]+1][skill[2]] -= damage;
    if (skill[4]+1 < board[0].length && skill[3]+1 < board.length) board[skill[3]+1][skill[4]+1] += damage;
}

function solution(board, skill) {
    var answer = 0;
    let aBoard = new Array(board.length).fill(0).map(e => new Array(board[0].length).fill(0))
    for(let i in skill) {
        effect(aBoard,skill[i])
        //console.log(aBoard)
    }

    for(let i=0; i<aBoard.length; i++) {
        for (let j=1; j<aBoard.length; j++) {
            aBoard[i][j] += aBoard[i][j-1]; 
        }
    }

    for(let i=0; i<aBoard.length; i++) {
        for (let j=1; j<aBoard.length; j++) {
            aBoard[j][i] += aBoard[j-1][i]; 
        }
    }

    for(let i=0; i<aBoard.length; i++) {
        for (let j=0; j<aBoard.length; j++) {
            board[i][j] += aBoard[i][j]; 
        }
    }

    for(let i in board) {
        for (let j in board[i]) {
            if(board[i][j] > 0) answer += 1; 
        }
    }
    return answer;
}
  • 두나

    감사합니다~

    두나―2022.09.20 01:39
0 개의 답변
답변 쓰기
이 입력폼은 마크다운 문법을 지원합니다. 마크다운 가이드 를 참고하세요.