Javascript-specific method for calculating the number split of 1 in binary

Source: Internet
Author: User

Code As follows: Copy code The Code is as follows: function g (n ){
VaR n = n. tostring (2 );
VaR COUNT = 0;
For (VAR I = 0; I <n. length; I ++)
{
If (N [I] = "1 ")
Count ++;
}
Return count;
}

I think this writing is very troublesome. I suddenly thought that I could use the JS split method to calculate the number of 1. The split parameter is regular \ 0 * \, which separates 1 in the string. The Code is as follows:Copy codeThe Code is as follows: function f (n ){
Return N. tostring (2). Split (/0 */). length;
}

In this way, the code is very concise.

It is a pity that the efficiency of the two methods is tested. It is found that the efficiency of the regular split method is relatively low, and the time is about 2.5 times that of the for loop method.
[Ctrl + A select all Note: If you need to introduce external JS, You need to refresh it to execute]

Two errors are found in the original code.

First, in IE, strings cannot use array subscript to access the value at the specified position. They can only use charat (index.

Second, in chrome and opera, the split (\ 0 * \) method calculates the number of 1 values, which may increase by 1 in some cases.

For example, if the binary value of 12 is 1100, the array generated by Split (\ 0 * \) is [1, 1,]. That is to say, when the binary value does not end with 1, an empty array item will be generated at the end (this problem is not found in IE and Firefox ).

After thinking, we found that we do not need to use regular expressions to calculate the number of 1. We only need to use 1 as a parameter of the split method and 1 as a separator, the length of the split array should be 1 plus 1.Copy codeThe Code is as follows: function f (n ){
Return N. tostring (2). Split ("1"). Length-1;
}

in this way, the regular expression method is not used and compatible with mainstream browsers, and its efficiency is not lower than the for Traversal method.
[Ctrl + A select all Note: To introduce external JS, refresh it before execution]

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.