๐ฅ Algorithm/Programmers
[ํ๋ก๊ทธ๋๋จธ์ค Lv.2] ์ ๊ณ ๊ฒฐ๊ณผ ๋ฐ๊ธฐ(js)
Lennon
2022. 1. 22. 08:08
728x90
๋ฐ์ํ
https://programmers.co.kr/learn/courses/30/lessons/92334?language=javascript#
function solution(id_list, report, k) {
report = [...new Set(report)].map(v => v.split(' '));
const reported = report.map(v => v[1]);
const reportCount = new Array(id_list.length).fill(0);
const kReported = [];
reported.forEach(v => {
reportCount[id_list.indexOf(v)]++;
})
reportCount.forEach((v,idx) => {
if(v >= k){
kReported.push(id_list[idx]);
}
})
const answer = new Array(id_list.length).fill(0);
report.forEach((v,idx) => {
if(kReported.includes(v[1])){
answer[id_list.indexOf(v[0])]++;
}
})
return answer
}
๋จผ์ ์ ๊ณ ๋ ํ๋๋ง ์ ์ฉ๋๋ฏ๋ก Set์ ์ด์ฉํด report์ ๋ํด ์ค๋ณต๊ฐ์ ์์ ์ค๋ค.
reported => ์ ๊ณ ๋ ์ฌ๋๋ค ๋ฐฐ์ด
reportCount => ์ ๊ณ ํ์ ๊ฒ์ฆ์ ์ํ ๋ฐฐ์ด
kReported => k๋ฒ ์ด์ ์ ๊ณ ๋ฐ์ ์ฌ๋๋ค์ ์ํ ๋ฐฐ์ด
7-9 line
์ฌ๋ ๋ณ ์ ๊ณ ํ์๋ฅผ ์ธ์ด reportCount์ ์ ์ฅ (indexOf๋ฅผ ํ์ฉ)
11-15 line
์ ๊ณ ํ์๊ฐ k๋ณด๋ค ๋์ ์ฌ๋์ kReported ๋ฐฐ์ด์ push
19-23 line
report๋ฅผ ์ํํ๋ฉฐ k๋ฒ ์ด์ ์ ๊ณ ๋ฅผ ๋นํ ์ฌ๋์ ์ ๊ณ ํ ์ฌ๋์ ํ์๋ฅผ 1๊ฐ์ฉ ์ฆ๊ฐ
์นด์นด์คํก 2022 ๊ณต์ฑ ์ ์ผํ 1๋จ๊ณ ๋ฌธ์ ์ด๋ค. ๋จ์ ๊ตฌํ๋ฌธ์ ๋ผ ๋๋ถ๋ถ์ด ๋ง์์๊ฑฐ๋ผ ์๊ฐํ๋ค.
728x90
๋ฐ์ํ