처리해야 할 작업이 N개가 대기중이고 이를 처리하기위한 CPU가 있습니다. N개의 작업은 모두 동일한 작업이라고 가정합니다.
작업을 수행하는 CPU에는 여러개의 코어가 있는데요. 코어별로 한 작업당 걸리는 시간이 다릅니다. 한 코어에서 작업이 끝나면 빈 코어에 다음 작업이 바로 들어가며, 2개 이상의 코어가 남을 경우 앞의 코어부터 채워줍니다. 처리해야 될 작업의 개수 n과, 각 코어의 처리 시간이 담긴 배열 core가 주어질 때, 마지막 작업이 들어가는 코어의 번호를 반환해주는 getCoreNumber 함수를 완성하세요.
예를 들어 작업이 6개이고, CPU의 코어별 처리 시간이 [1,2,3] 이라면 처음 3개의 작업은 각각 1,2,3번에 들어가고, 1의 시간 뒤 1번 코어에 4번째 작업, 다시 1의 시간 뒤 1,2번 코어에 5,6번 째 작업이 들어가므로 2를 반환해 주면 됩니다.
function getCoreNumber(n, core) {
var answer = 0;
var coores = [];
n = n - core.length;
for (var i = 0; i < core.length; i++) {
var tick = {};
tick["tick"] = core[i] - 1;
tick["core"] = (i + 1);
coores.push(tick);
}
while (n != 0) {
for (var i = 0; i < coores.length; i++) {
if (coores[i]["tick"] == 0) {
coores[i]["tick"] = core[i];
n--;
if (n == 0) {
answer = coores[i]["core"];
return answer
}
}
coores[i]["tick"] = coores[i]["tick"] - 1;
}
}
}
// 아래는 테스트로 출력해 보기 위한 코드입니다.
//console.log(getCoreNumber(61391213, [12, 26, 12, 22, 8, 6, 3, 29, 13]));
'JavaScript' 카테고리의 다른 글
CheckBox Jquery 컨트롤 (0) | 2022.08.09 |
---|---|
JQuery Select Box 제어 (0) | 2019.01.03 |
[Javascript] check시 사용,사용불가 (0) | 2018.09.06 |
insertAdjacentHTML() 이벤트 리스너 (0) | 2018.09.04 |