728x90
문제
https://www.acmicpc.net/problem/23288
풀이
해당 문제는 구현이 조금 까다로울뿐 BFS를 이용한 탐색 문제이다.
주사위가 굴러가는 조건들을 조심히 구현하는 것이 중요하다. 필자도 조건을 잘못 설정해서 10분정도 해맸다...
주사위가 굴러간 좌표에 있는 숫자와 주사위 하단의 숫자를 비교한 뒤 주사위를 굴릴 방향을 정하고, 현재 위치의 숫자의 크기와 인접 좌표에 같은 숫자의 개수를 구해주면 문제의 풀이는 끝난다.
인접 좌표에서 같은 숫자의 수를 구할 때 BFS가 사용되는데, 필자는 주사위를 굴릴때 마다 방문 여부를 기록하는 객체를 생성해 방문여부를 기록했다.
코드
const input = require('fs')
.readFileSync(process.platform === 'linux' ? '/dev/stdin' : __dirname + '/example.txt')
.toString().trim().split('\n');
const [n, m, c] = input.shift().split(' ').map(Number);
const map = input.map(e => e.split(' ').map(Number));
const dice = {
up: 1,
right: 3,
left: 4,
north: 2,
south: 5,
bottom: 6,
pos: [0, 0]
};
const dir = [[0, 1], [1, 0], [0, -1], [-1, 0]];
let fD = 0;
let answer = 0;
for (let i = 0; i < c; i++){
const [curY, curX] = dice.pos;
const up = dice.up;
let [nY, nX] = [curY + dir[fD][0], curX + dir[fD][1]];
let cnt = 1;
if (nY < 0 || nY >= n || nX < 0 || nX >= m) {
fD = (fD + 2) % 4;
}
if (fD === 0) {
dice.up = dice.left;
dice.left = dice.bottom;
dice.bottom = dice.right;
dice.right = up;
}
else if (fD === 1) {
dice.up = dice.north;
dice.north = dice.bottom;
dice.bottom = dice.south;
dice.south = up;
}
else if (fD === 2) {
dice.up = dice.right;
dice.right = dice.bottom;
dice.bottom = dice.left;
dice.left = up;
}
else if (fD === 3) {
dice.up = dice.south;
dice.south = dice.bottom;
dice.bottom = dice.north;
dice.north = up;
}
dice.pos = [dice.pos[0] + dir[fD][0], dice.pos[1] + dir[fD][1]];
const visited = {};
const que = [[dice.pos[0], dice.pos[1]]];
visited[`${que[0][0]} ${que[0][1]}`] = true;
while (que.length > 0) {
const [y, x] = que.shift();
for (let j = 0; j < 4; j++){
const [ny, nx] = [y + dir[j][0], x + dir[j][1]];
if (ny >= 0 && ny < n && nx >= 0 && nx < m && map[ny][nx] === map[dice.pos[0]][dice.pos[1]] && !visited[`${ny} ${nx}`]) {
visited[`${ny} ${nx}`] = true;
que.push([ny, nx]);
cnt++;
}
}
}
answer += (cnt * map[dice.pos[0]][dice.pos[1]])
const [nextY, nextX] = dice.pos;
if (map[nextY][nextX] < dice.bottom) {
fD = (fD + 1) % 4;
}
else if (map[nextY][nextX] > dice.bottom) {
fD = (4 + fD - 1) % 4;
}
}
console.log(answer);
728x90
'코딩 테스트 > 백준' 카테고리의 다른 글
[JS] 마법사 상어와 비바라기 (0) | 2024.11.27 |
---|---|
[JS] 2573_빙산 (0) | 2024.11.26 |
[JS] 바이러스 (0) | 2024.11.06 |
[JS] 벌집 (0) | 2024.10.30 |
[JS] 수들의 합2 (0) | 2024.10.26 |