๐ฅ Algorithm/Baekjoon
[๋ฐฑ์ค 1744๋ฒ] ์ ๋ฌถ๊ธฐ - ์๋ฐ์คํฌ๋ฆฝํธ(nodejs)
Lennon
2022. 2. 18. 21:25
728x90
๋ฐ์ํ
https://www.acmicpc.net/problem/1744
const fs = require('fs');
const [n, ...input] = fs.readFileSync('../input.txt').toString().trim().split('\n').map(Number);
const negative = [];
const positive = [];
let zero = 0;
let answer = 0;
input.forEach((v) => {
if (v < 0) {
negative.push(v);
} else if (v > 1) {
positive.push(v);
} else if (v === 0) {
zero++;
} else {
answer++;
}
});
negative.sort((a, b) => b - a);
positive.sort((a, b) => a - b);
while (positive.length) {
if (positive.length === 1) {
answer += positive.pop();
break;
}
const value = positive.pop();
const value2 = positive.pop();
answer += value * value2;
if (positive.length === 1) {
answer += positive.pop();
break;
}
}
while (negative.length) {
if (negative.length === 1) {
if (zero !== 0) {
zero--;
break;
} else {
answer += negative.pop();
break;
}
}
if (negative.length % 2 === 1 && zero !== 0) {
negative.shift();
zero--;
}
const value = negative.pop();
const value2 = negative.pop();
answer += value * value2;
if (negative.length === 1) {
answer += negative.pop();
break;
}
}
console.log(answer);
1์ ์์์ ๊ณฑํ๋ฉด ๋ํ๋ ๊ฐ์ด ์์์ง๋ฏ๋ก ex) 1, 11 => ๊ณฑํ๋ฉด 11 or ๋ํ๋ฉด 12 ๊ทธ๋ฅ answer์ 1์ ๋ํด์ค๋ค.
์์ ์์๋ฅผ ๋ฐ๋ก ๋ฐฐ์ด์ ์ ์ฅํด sort๋ก ์ ๋ ฌํ ํ ํ์, ์ง์ ๊ฐ์๋ฅผ ์๊ฐํ๋ฉฐ ์๊ณ ๋ฆฌ์ฆ์ ๊ตฌ์ฑํ๋ค.
๋ง์ฝ 0์ด ์์ ๋๋ ์์๊ฐ ํ์์ผ ๋ ์์์ค์ ๊ฐ์ฅ ํฐ ๊ฐ์ด๋ ๊ณฑํด์ค์ผ ํฉ์ด ์ต๋์ด๋ค.
๊ทธ๋ฆฌ๊ณ , ์์, ์์๊ฐ 1๊ฐ์ฉ๋ง ์์ ๋๋ฅผ ์๊ฐํด ์๊ณ ๋ฆฌ์ฆ์ ๊ตฌ์ํ๋ฉด ์ฝ๊ฒ ํ ์ ์๋ค.
728x90
๋ฐ์ํ