Skip to content

Instantly share code, notes, and snippets.

@vedantb
Created May 10, 2020 08:08
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save vedantb/223267865e6fe4b26b22ed16e4bb7ebf to your computer and use it in GitHub Desktop.
Save vedantb/223267865e6fe4b26b22ed16e4bb7ebf to your computer and use it in GitHub Desktop.
/**
* @param {number} num
* @return {boolean}
*/
var isPerfectSquare = function(num) {
if (num < 2) return true;
let left = 2;
let right = Math.floor(num / 2);
while (left <= right) {
let mid = left + Math.floor((right - left) / 2);
let guess = mid * mid;
if (guess === num) return true;
if (guess > num) {
right = mid - 1;
} else {
left = mid + 1;
}
}
return false;
};
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment