The square root of Leetcode 69.x
Offer to come, dig friends take it! I am participating in the 2022 Spring Recruit Punch card activity. Click here for details.
1. Title
Given a non-negative integer x, compute and return the arithmetic square root of x.
Since the return type is an integer, only the integer part of the result is retained, and the decimal part is omitted.
** Note: ** does not allow the use of any built-in exponential functions and operators, such as POw (x, 0.5) or x ** 0.5.
Example 1:
Enter: x = 4
Output: 2
Example 2:
Enter: x = 8
Output: 2
Explanation: The arithmetic square root of 8 is 2.82842… Because the return type is an integer, the decimal part will be omitted.
Limitations:
0 <= x <= 231 - 1
2. Ideas
Method one: dichotomy
As we can see from the requirements and examples of the question, is a search for an integer, and the integer is a range.
- The square of the integer is equal to the input integer, which is found;
- The square of the integer is greater than the input integer, which must not be the number we’re looking for, which must come before the number.
- The square of an integer is less than the input integer, which might be the number we’re looking for.
Be sure to clarify the logic of the program, determine the final pointer to the program.
Method two: Newton iteration method
Belongs is an iterative solution process, that is, the use of recursive solution. The proof process is shown below
We get the formula :(x + a/x) / 2 a is the number that we need to solve for the square root of arithmetic, a constant value and x is the value of the zero that we need to solve for
Less nonsense ~~~~~ on the code!
3. Code:
Commit AC for the first time
class Solution {
public int mySqrt(int x) {
if(x == 0) return 0;
if(x == 1) return 1;
int R = x;
int L = 0;
while(L <= R) {
int M = L + ((R-L) >> 1);
if(M > (long)x / M){
//L... M-1
R = M - 1;
}else{
//M.... R
L = M + 1; }}returnR; }}Copy the code
Time complexity: O(log N) The size of each search interval is about half of the original
Space complexity: O(1)
Commit the SECOND TIME
class Solution {
int a;
public int mySqrt(int x) {
a = x;
if(x == 0) return 0;
if(x == 1) return 1;
double result = (x + a / x) >> 1;
double x1 = x;
while(true){
result = (x1 + a / x1) / 2;
if(result == x1){
break;
}
x1 = result;
}
return (int) result; }}Copy the code
Time complexity: O(log N) This method is convergent and faster than binary search.
Space complexity: O(1)
4, summarize
The topic of the use of binary search application example, first of all to understand the binary method.
Dichotomy template:
public static int binarysearch(int arr[], int L, int R, int target){
int count = 0;
int M = (L + R) >> 1;
if(L > R) return -1;
if (target > arr[M]){
return binarysearch(arr, M + 1, R, target);
}else if(target < arr[M]){
return binarysearch(arr, L, M - 1, target);
}else {
returnM; }}Copy the code
from the LeetCode Basic Algorithms column subscribe to
The original intention of the director to write blog is very simple, I hope everyone in the process of learning less detours, learn more things, to their own help to leave your praise or pay attention to are the biggest support for me, your attention and praise to the director every day more power.
If you don’t understand one part of the article, you can reply to me in the comment section. Let’s discuss, learn and progress together!
Square root of 69. X – Force buckle (LeetCode)