Sqrt(x)

신병규·2022년 9월 28일
0

Algorithm

목록 보기
5/6
post-custom-banner

음수가 아닌 정수 x가 주어지면 x의 제곱근을 계산하여 반환해야 합니다.
반환 유형이 정수이므로 소수 자릿수가 잘리고 결과 중 정수 부분만 반환됩니다.
참고: pow(x, 0.5) 또는 x ** 0.5와 같은 기본 제공 지수 함수 또는 연산자를 사용할 수 없습니다.

Example 1:

Input: x = 4
Output: 2

Example 2:

Input: x = 8
Output: 2
Explanation: The square root of 8 is 2.82842..., and since the decimal part is truncated, 2 is returned.
/**
 * @param {number} x
 * @return {number}
 */
var mySqrt = function (x) {

  if (x === 0) {
    return 0
  }
  let i = 1;

  while (i * i <= x) {
    i++
  }
  if (i > 1) {
    i--
  }

  return (i)
};

제곱근의 정수부분만 리턴하라는 조건으로 구간을 나눠 찾음

최다 추천 코드

  var mySqrt = function(x) {
  var left = 1;
  var right = Math.floor(x / 2) + 1;
  var mid;

  while (left <= right) {
    mid = Math.floor((left + right) / 2);

    if (mid * mid > x) {
      right = mid - 1;
    } else if (mid * mid < x) {
      left = mid + 1;
    } else {
      return mid;
    }
  }

  return right;
};

이진탐색 이용

post-custom-banner

0개의 댓글