정수가 있을 때, 짝수라면 반으로 나누고, 홀수라면 1을 뺀 뒤 반으로 나누면, 마지막엔 1이 됩니다. 예를 들어 10이 있다면 다음과 같은 과정으로 1이 됩니다. 10 / 2 = 5 (5 - 1) / 2 = 4 4 / 2 = 2 2 / 2 = 1 위와 같이 4번의 나누기 연산으로 1이 되었습니다. 정수들이 담긴 리스트 num_list가 주어질 때, num_list의 모든 원소를 1로 만들기 위해서 필요한 나누기 연산의 횟수를 return하도록 solution 함수를 완성해주세요.
class Solution {
public int solution(int[] num_list) {
int answer = 0;
for(int i=0;i<num_list.length; i++){
while(num_list[i] != 1){
answer++;
if(num_list[i]%2 ==0){
num_list[i]/=2;
}else {
num_list[i]=(num_list[i]-1)/2;
}
}
}
return answer;
}
}
for 문 안에서 그 수가 1이 될때까지 while 문을 돌려줘서 답을 구하면 된다.!!
'자바 알고리즘 문제' 카테고리의 다른 글
| 수열과 구간 쿼리 3 (1) | 2023.11.24 |
|---|---|
| 팩토리얼 (0) | 2023.11.23 |
| 2차원으로 만들기 (2) | 2023.11.21 |
| 문자열 뒤집기 (2) | 2023.11.21 |
| 문자열 섞기 (2) | 2023.11.20 |