Common errors of '/' operator in javascript_javascript tips
//Forgetful recursive version of binary search
function binary_search(arr, target,low,high){
if(low
if(target>arr[min])
return binary_search(arr,target,min 1,high);
else
return binary_search(arr,target,low,min);
}else if(low==high){ //only There is one element left
if(arr[low]==target)
return low;
else return -1;
}else if(low>high){ //Empty, use arr .length-1 should be considered when calculating the initial high of arr.
return -1;
}
}
var arr=[1,2,3,4, 5,6];
alert(binary_search(arr,3,0,arr.length-1));
Looking at the data structure at night, I wrote a binary search algorithm in js (the code is as above), and then I randomly wrote an array as the test data (as above). According to the idea, it should output the subscript of the search target, but something unexpected happened. I saw the CPU spinning wildly for an instant. After about two seconds, the browser automatically terminated the script. running, and then I felt puzzled for a while.
According to experience, there should be an infinite loop in the process of running the script. I looked at the algorithm during self-study and found no problems (you can just enter the code directly according to the textbook and you will not be wrong) , but the problem remains. So I added an output statement to the first judgment condition, as follows:
//Binary search forgetful recursive version function binary_search(arr,target,low,high){
if(low
if(target>arr[min])
return binary_search(arr,target,min 1,high);
else
return binary_search(arr,target,low,min) ;
}else if(low==high){ //Only one element left
if(arr[low]==target)
return low;
else return -1;
}else if(low>high){ //Empty, it should be considered when using arr.length-1 to calculate the initial high of arr
return -1;
}
}
Run it, and a dialog box will pop up with the number 2.5~~ Suddenly, I suddenly have the urge to smash the computer.
Cause of error and summary:
The "/" operator in JavaScript is different from the "/" operator in C. The latter is automatically rounded, while the former will get a decimal if it is not divided by integers (for example 5/2=2.5).
Solution:
(1)var min=parseInt((low high)/2);
(2)var min=Match.floor((low high)/2);

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



In the C language, there is no root operator. The built-in function "sqrt()" is used to open the root, and the syntax "sqrt(value x)" is used; for example, "sqrt(4)" is to perform the square root operation on 4. , the result is 2. sqrt() is a built-in root operation function in C language. Its operation result is the arithmetic square root of the function variable; this function can neither operate negative values nor output imaginary results.

For Golang developers, "invaliduseof...operator" is a common error. This error usually occurs when using variable-length parameter functions. It will be detected at compile time and indicate which parts have problems. This article will introduce how to solve this error. 1. What is a variable-length parameter function? A variable-length parameter function is also called a variable-parameter function. It is a function type in the Golang language. Using variable-length parameter functions, you can define multiple ones as follows

In Java, "%" means remainder. It is a binary arithmetic operator that can perform division operations and obtain the remainder. The syntax is "operand 1 % operand 2". The operand of the remainder operator "%" is usually a positive integer or a negative number or even a floating point number. If a negative number participates in this operation, the result depends on whether the previous number is positive or negative.

The += operator is used to add the value of the left operand to the value of the right operand and assign the result to the left operand. It is suitable for numeric types and the left operand must be writable.

In PHP, the "==" symbol is a comparison operator that can compare whether two operands are equal. The syntax is "operand 1 == operand 2". The "==" operator compares and tests whether the variable on the left (expression or constant) has the same value as the variable on the right (expression or constant); it only compares the values of the variables, not the data types. If the two values are the same, it returns a true value; if the two values are not the same, it returns a false value.

In PHP, you can use the "%" and "==" operators to determine whether two numbers are divisible; you only need to use the "%" operator to divide the two numbers to get the remainder, and then use the "==" operator Just judge whether the obtained remainder is 0. The syntax is "Number 1 % Number 2 == 0". If it is 0, it can be divisible. If it is not 0, it cannot be divisible.

Python is widely used in a wide range of fields with its simple and easy-to-read syntax. It is crucial to master the basic structure of Python syntax, both to improve programming efficiency and to gain a deep understanding of how the code works. To this end, this article provides a comprehensive mind map detailing various aspects of Python syntax. Variables and Data Types Variables are containers used to store data in Python. The mind map shows common Python data types, including integers, floating point numbers, strings, Boolean values, and lists. Each data type has its own characteristics and operation methods. Operators Operators are used to perform various operations on data types. The mind map covers the different operator types in Python, such as arithmetic operators, ratio

Magic methods in Python are special methods that allow you to add "magic" to a class. They are often named surrounded by two underscores. Python's magic method, also known as the dunder (double underline) method. Most of the time, we use them for simple things like constructors (init), string representations (str, repr) or arithmetic operators (add/mul). In fact, there are many methods that you may not have heard of but are very useful. In this article, we will sort out these magic methods! We all know the size of the iterator __len__ method, which can be used in container classes Implement the len() function on. However, if you want to get the length of a class object that implements iterator
