정수가 있을 때, 짝수라면 반으로 나누고, 홀수라면 1을 뺀 뒤 반으로 나누면, 마지막엔 1이 됩니다. 예를 들어 10이 있다면 다음과 같은 과정으로 1이 됩니다.
위와 같이 3번의 나누기 연산으로 1이 되었습니다.
정수들이 담긴 리스트 num_list가 주어질 때, num_list의 모든 원소를 1로 만들기 위해서 필요한 나누기 연산의 횟수를 return하도록 solution 함수를 완성해주세요.
function solution(num_list) {
let result = 0;
for (let i=0; i<num_list.length; i++){
let el = num_list[i]
while (el!==1){
result++;
if (el%2===0){
el=el/2
} else {
el=(el-1)/2
}
}
}
return result;
}
반복문을 통해 배열의 요소를 하나씩 확인한다. 1이 아닐 경우 짝수 및 홀수 조건에 따라 계속 계산한다. 이 때 한 번 계산할 때마다 result에 1씩 더한다. 반복문이 끝나고 나면 result를 return하여 문제를 해결했다.