Algorithm/Level 0

[Level 0] 정수 반복 계산

쩨리쩨리 2023. 7. 27. 08:39
반응형

문제

문자열 S 는 이진수로 표현된 양의 정수이다.

해당 정수에 대해서 아래의 연산을 수행한다.
- 만약 숫자가 짝수인 경우 해당 값을 2로 나눈다.
- 만약 숫자가 홀수인 경우 1을 뺀다.

연산의 결과가 0이 될 때까지 위 동작을 반복해서 수행했을 때, 수행된 연산의 횟수를 구하는 프로그램을 구현하라.

 

입력 형식

  • 이진수로 이루어진 문자열 S

 

출력 형식

  • 결과가 0이 될 때까지 필요한 연산 횟수를 정수로 반환

 

제약 사항

  • 0 < S.length <= 100

 

입출력 예시

  • 입력 : S = "1101"
  • 출력 : 6
  • 설명 : 1101은 십진수로 13이며, 아래와 같은 순서로 6번 동작한 후에 종료된다.
    13 → 12 → 6 → 3 → 2 → 1 → 0

 


내 풀이

function solution(S) {
    const num = parseInt(S,2);
    return operation(num,0);
}
function operation(n, count){
    if (n === 0) return count;

    if(n % 2 === 0) {
        return operation(n/2, ++count);
    }else{ 
        return operation(n-1, ++count);
    }
}

 

  • 시간 복잡도 : O(log n)
  • 설명 : 입력 값인 n이 2로 나눠질 때마다 절반으로 줄어든다. 이진수로 표현된 n을 계속해서 절반으로 나누면서 재귀적으로 함수를 호출하므로 시간 복잡도는 O(log n)이다.
    이 코드는 이진수로 표현된 n을 2로 나누거나 1을 빼는 작업을 반복하면서 0이 될 때까지의 연산 횟수를 구하는 함수이다. 따라서 입력 값 n의 이진수 표현에서 1의 개수를 세는 것과 동일한 기능을 수행한다. 이 코드는 주어진 이진수를 2로 나누거나 1을 빼는 작업을 반복하면서 이진수의 1의 개수를 구하므로 효율적인 방법이다. 입력 값 n이 매우 크더라도 이진수의 길이에 따라 연산 횟수가 크게 줄어들어 효율적인 알고리즘이다.

 


 

반응형