์ผ | ์ | ํ | ์ | ๋ชฉ | ๊ธ | ํ |
---|---|---|---|---|---|---|
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 |
- ๋ฆฌ์กํธ์ฟผ๋ฆฌ suspense
- ์นด์นด์ค ์ฝํ
- js ๋ฌธ์์ด ์์ถ
- ๊ตฌ๋ฆํค ์ฑ๋ฆฐ์ง
- ์๋ฐ์คํฌ๋ฆฝํธ ๋ฌธ์์ด ์์ถ
- ํ๋ก๊ทธ๋๋จธ์ค ๊ฑฐ๋ฆฌ๋๊ธฐ ํ์ธํ๊ธฐ
- app router emotion
- js
- ๊ตฌ๋ฆํค
- emtion app router
- ๋ฐฑ์ค 2108 ์๋ฐ์คํฌ๋ฆฝํธ
- suspense react-query
- suspense ๋์์๋ฆฌ
- js ์ค์ฝํ
- ํ๋ก๊ทธ๋๋จธ์ค ๋ฌธ์์ด ์์ถ
- ์ฌ์ฉ์ฑ ๊ฐ์
- next13 emotion
- ์๋ฐ์คํฌ๋ฆฝํธ ์ค์ฝํ
- js ๊ฑฐ๋ฆฌ๋๊ธฐ ํ์ธํ๊ธฐ
- ์ต์ ๋์ฒด์ด๋
- ๊ตฌ๋ฆํค ์ฑ๋ฆฐ์ง ํ๊ณ
- ๋ฐฑ์ค 1339๋ฒ nodejs
- suspense ๋น๋๊ธฐ
- ๋ฐฑ์ค 2108 nodejs
- ๋ฐฑ์ค 1339๋ฒ ์๋ฐ์คํฌ๋ฆฝํธ
- TypeError: createContext only works in Client Components. Add the "use client" directive at the top of the file to use it. Read more:
- ์ค์ฝํ
- suspense ๋ณ๋ชฉํ์
- emotion RSC
- ๋ฐฑ์ค 1339๋ฒ js
- Today
- Total
Lennon FE
[๋ฐฑ์ค 17144๋ฒ] ๋ฏธ์ธ๋จผ์ง ์๋ ! - ์๋ฐ์คํฌ๋ฆฝํธ(nodejs) ๋ณธ๋ฌธ
[๋ฐฑ์ค 17144๋ฒ] ๋ฏธ์ธ๋จผ์ง ์๋ ! - ์๋ฐ์คํฌ๋ฆฝํธ(nodejs)
Lennon 2022. 3. 16. 05:19ใ https://www.acmicpc.net/problem/17144
์ด๋ฒ ๊ตฌํ๋ฌธ์ ๋ ๋นก๊ตฌํ ๋ฌธ์ ์์ค์ด๋ผ ์ฝ๋๊ฐ ์ ๋ง ๊ธธ๋ค... ๋ ์ค์ผ ์ ์์ง๋ง ํธ๋๋ผ ์ง์ณ๋ฒ๋ ธ๋ค.
const readline = require('readline');
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout,
});
let input = [];
rl.on('line', function (line) {
input.push(line);
if (input.length === +input[0].split(' ')[0] + 1) {
rl.close();
}
}).on('close', function () {
let [R, C, time] = input.shift().split(' ').map(Number);
let house = input.map((v) => v.split(' ').map(Number));
const airCleanerIdx = house.map((v) => v[0]).indexOf(-1);
let answer = 0;
while (time) {
house = diffusionDust(house); // ๋ฏธ์ธ๋จผ์ง ํ์ฅ
const antiClockwise = antiClockwiseRotation(house, airCleanerIdx); // ๋ฐ์๊ณ ํ์
const clockwise = clockwiseRotation(house, airCleanerIdx); // ์๊ณ ํ์
house = antiClockwise.concat(clockwise); // ๋ฐ์๊ณ + ์๊ณ ๋ฐฐ์ด ํฉ์น๊ธฐ
answer = house.reduce((acc, cur) => acc + cur.reduce((a, c) => a + c), 0) + 2;
time--;
}
console.log(answer);
});
function diffusionDust(arr) {
const list = [];
for (let i = 0; i < arr.length; i++) {
for (let j = 0; j < arr[i].length; j++) {
if (arr[i][j] === 0 || arr[i][j] === -1) continue;
const value = Math.floor(arr[i][j] / 5);
let cnt = 0;
if (i < arr.length - 1 && arr[i + 1][j] !== -1) {
list.push([i + 1, j, value]);
cnt++;
}
if (i > 0 && arr[i - 1][j] !== -1) {
list.push([i - 1, j, value]);
cnt++;
}
if (j < arr[i].length - 1 && arr[i][j + 1] !== -1) {
list.push([i, j + 1, value]);
cnt++;
}
if (j > 0 && arr[i][j - 1] !== -1) {
list.push([i, j - 1, value]);
cnt++;
}
arr[i][j] -= value * cnt;
}
}
list.forEach((v) => {
const [i, j, value] = v;
arr[i][j] += value;
});
return arr;
}
function clockwiseRotation(arr, idx) {
const clockwiseArr = [];
for (let i = 0; i < arr.length; i++) {
if (i > idx) {
clockwiseArr.push(arr[i]);
}
}
const value = [];
value.push(...clockwiseArr[0].slice(1));
for (let i = 1; i < clockwiseArr.length - 1; i++) value.push(clockwiseArr[i][clockwiseArr[1].length - 1]);
value.push(...clockwiseArr[clockwiseArr.length - 1].reverse());
clockwiseArr[clockwiseArr.length - 1].reverse();
for (let i = clockwiseArr.length - 2; i > 0; i--) value.push(clockwiseArr[i][0]);
value.pop();
let x = 1;
let y = 0;
while (x < clockwiseArr[1].length - 1) {
clockwiseArr[y][++x] = value.shift();
}
while (y < clockwiseArr.length - 1) {
clockwiseArr[++y][x] = value.shift();
}
while (x > 0) {
clockwiseArr[y][--x] = value.shift();
}
while (y > 0) {
clockwiseArr[--y][x] = value.shift();
}
clockwiseArr[0][0] = -1;
clockwiseArr[0][1] = 0;
return clockwiseArr;
}
function antiClockwiseRotation(arr, idx) {
const antiClockwiseArr = [];
for (let i = 0; i < arr.length; i++) {
if (i <= idx) {
antiClockwiseArr.push(arr[i]);
} else break;
}
const value = [];
value.push(...antiClockwiseArr[idx].slice(1));
for (let i = idx - 1; i > 0; i--) value.push(antiClockwiseArr[i][antiClockwiseArr[i].length - 1]);
value.push(...antiClockwiseArr[0].reverse());
antiClockwiseArr[0].reverse();
for (let i = 1; i < idx; i++) value.push(antiClockwiseArr[i][0]);
value.pop();
let x = 1;
let y = idx;
while (x < antiClockwiseArr[1].length - 1) {
antiClockwiseArr[y][++x] = value.shift();
}
while (y > 0) {
antiClockwiseArr[--y][x] = value.shift();
}
while (x > 0) {
antiClockwiseArr[y][--x] = value.shift();
}
while (y < idx) {
antiClockwiseArr[++y][x] = value.shift();
}
antiClockwiseArr[idx][1] = 0;
antiClockwiseArr[idx][0] = -1;
return antiClockwiseArr;
}
diffusionDust ํจ์
- ๋ฏธ์ธ๋จผ์ง๋ฅผ ํ์ฅ์ํค๋ ํจ์์ด๋ค. ์ฃผ์ํด์ผํ ์ ์ ๊ฐ๊ฐ ์์๋๋ก ์ํ์ข์ฐ ํ๋ณ ํด์ฃผ๋ ๊ฒ ์๋๋ผ, 0์ด์๋ ์ฆ ์ด ์ ์ ๊ฐ์ด ์์๋ ๊ณณ์ ํ์ฅ์ผ๋ก ์ธํด ์๋ก์ด ๊ฐ์ด ์ถ๊ฐ๋์ด๋ ์ํํ ๋ ๊ทธ ๊ณณ์ ๊ทธ๋ฅ ์ง๋์ณ์ผ ํ๋ค.
์ด๋ ๊ฒ ๋์ค๊ณ ๋๋ด์ผ๋๋๋ฐ, ๊ณ์ ์งํํ๋ฉด 10 ๋ค์ 9๋ก ๊ฐ์ ๋ค์ ์งํ๋๊ณ , ๊ทธ ๋ค์ (2,2)์ ์์นํ 9์ ๊ฐ์ ๋ ์งํ๋์ด ์๋ง์ง์ฐฝ์ด ๋ ๊ฒ์ด๋ค.
diffusionDustํจ์์์ list ๋ฐฐ์ด์ ๋ง๋ค์ด ์กฐ๊ฑด์ ๋ง์ผ๋ฉด i,j ์ธ๋ฑ์ค์ value๊ฐ์ ๋ฃ๊ณ ๋ง์ง๋ง์ ํ๊บผ๋ฒ์ ๊ฐ์ค์น๋ฅผ ๋ํด์ฃผ์๋ค.
clockwiseRotation ํจ์
antiClockwiseRotation ํจ์
'๐ฅ Algorithm > Baekjoon' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
[๋ฐฑ์ค 1309๋ฒ] ๋๋ฌผ์ - ์๋ฐ์คํฌ๋ฆฝํธ(nodejs) (0) | 2022.03.18 |
---|---|
[๋ฐฑ์ค 1260๋ฒ] DFS์ BFS - ์๋ฐ์คํฌ๋ฆฝํธ(nodejs) (0) | 2022.03.18 |
[๋ฐฑ์ค 1789๋ฒ] ์๋ค์ ํฉ - ์๋ฐ์คํฌ๋ฆฝํธ(nodejs) (0) | 2022.03.14 |
[๋ฐฑ์ค 1932๋ฒ] ์ ์ ์ผ๊ฐํ - ์๋ฐ์คํฌ๋ฆฝํธ(nodejs) (0) | 2022.03.11 |
[๋ฐฑ์ค 9095๋ฒ] 1, 2, 3 ๋ํ๊ธฐ - ์๋ฐ์คํฌ๋ฆฝํธ(nodejs) (0) | 2022.03.11 |