문제
https://www.acmicpc.net/problem/1913
풀이
1, 1 부터 시작해서 반시계방향으로 배열 만들어 간다.
만들다가 해당 숫자 나오면 좌표를 기록한다.
배열이 완성되면 배열과 좌표를 출력한다.
코드
let fs = require('fs');
// let input = fs.readFileSync('/dev/stdin').toString().split('\n');
let input = fs.readFileSync('./b1913.txt').toString().split('\n');
let readlineIdx = 0;
const readInput = () => input[readlineIdx++];
let dx = [0, 1, 0, -1];
let dy = [1, 0, -1, 0];
let answerLoca = { X: 0, Y: 2 };
function solution(table, t) {
let cnt = t * t;
let X = 0;
let Y = 0;
let nowDir = 0;
let moveCnt = t;
while (true) {
if (nowDir === 1) {
moveCnt--;
}
if (nowDir === 3) {
moveCnt--;
}
for (let i = 0; i < moveCnt; ++i) {
X = X + dx[nowDir];
Y = Y + dy[nowDir];
table[X][Y] = cnt--;
if (table[X][Y] === findNum) {
answerLoca = { X, Y };
}
}
if (cnt === 0) {
return;
}
nowDir = (nowDir + 1) % 4;
}
}
let findNum;
function main() {
let t = readInput();
t = parseInt(t, 10);
findNum = parseInt(readInput(), 10);
let table = new Array(t + 1);
for (let i = 0; i < t + 1; ++i) {
table[i] = new Array(t).fill(0);
}
solution(table, t);
for (let y = 1; y < t + 1; ++y) {
let string = "";
for (let x = 0; x < t; ++x) {
if (x === t - 1) {
string += table[x][y];
break;
}
string += table[x][y] + ' ';
}
console.log(string);
}
console.log(answerLoca.Y, answerLoca.X + 1);
}
main();
'알고리즘' 카테고리의 다른 글
[codility] MinAvgTwoSlice javascript (0) | 2021.01.19 |
---|---|
백준 9184 신나는 함수실행 javascript (0) | 2021.01.15 |
[백준] 5052 전화번호 목록 javascript (0) | 2021.01.11 |
[HackerRank] New Year Chaos (0) | 2021.01.08 |
[프로그래머스] 뉴스클러스터링 (0) | 2021.01.07 |