A brief discussion on the magic of parseInt() in JavaScript

A brief discussion on the magic of parseInt() in JavaScript

cause

The reason for writing this blog is that I was doing the daily question of Leetcode today. It is a question about converting a string to an integer (atoi). If you are interested, you can click on the title to see the detailed description. After I debugged it many times and finally submitted it successfully, I went to the comment section to see the experts' solutions. After reading it, I couldn't help but sigh that parseInt() in JavaScript is so excellent. This tells me a truth: the APIs that we think we are very familiar with may not be truly mastered by us. ”

My answer

/**
 * @param {string} str
 * @return {number}
 */
var myAtoi = function(str) {
    str = str.trim();
    //Intercept the first character of the string var firstChar = str.charAt(),res = '',regSymbol = /^[\-\+]{1}/,regNumber = /^[0-9]{1}/;

    if(!regSymbol.test(firstChar) && !regNumber.test(firstChar)){
        return 0;
    }

    //The first character is + or -
    if(regSymbol.test(firstChar)){
        var sliceStr = str.slice(1,str.length);
        for(var i=0;i<sliceStr.length;i++){
            if (regNumber.test(sliceStr.charAt(i))) {
                res += sliceStr.charAt(i);
            }else{
                break;
            }
        }
        
        (res.length) ? res = parseInt(firstChar + res) : res = 0;

        if(firstChar == '-' && res < Math.pow(-2,31)){
            res = Math.pow(-2,31);
        }

        if(firstChar == '+' && res > Math.pow(2,31) - 1){
            res = Math.pow(2,31) - 1;
        }

        return res;
    }

    //The first character is a number if (regNumber.test(firstChar)) {
        var sliceStr = str;
        for(var i=0;i<sliceStr.length;i++){
            if (regNumber.test(sliceStr.charAt(i))) {
                res += sliceStr.charAt(i);
            }else{
                break;
            }
        }

        if (parseInt(res) > Math.pow(2,31) - 1) {
            res = Math.pow(2,31) - 1;
        }

        return res;
    }
};

The answer from the boss

/**
 * @param {string} str
 * @return {number}
 */
var myAtoi = function(str) {
    const number = parseInt(str, 10);

    if(isNaN(number)) {
        return 0;
    } else if (number < Math.pow(-2, 31) || number > Math.pow(2, 31) - 1) {
        return number < Math.pow(-2, 31) ? Math.pow(-2, 31) : Math.pow(2, 31) - 1;
    } else {
        return number;
    }
};

By comparison, we know that parseInt() in JavaScript has performed a series of operations such as intercepting empty strings, judging the first letter, and returning number type results. It just happens to be a perfect match for today's daily question. It's so cool to use parseInt() to solve this problem.

This is the end of this article about the wonderful uses of parseInt() in JavaScript. For more relevant JavaScript parseInt() content, please search 123WORDPRESS.COM’s previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Exploration and correction of the weird behavior of parseInt() in js
  • Detailed explanation of JS conversion functions Number(), parseInt(), parseFloat()
  • In-depth understanding of Number(), parseInt(), and parseFloat() in JS
  • Detailed explanation of the difference between Number(), parseInt() and parseFloat() in js
  • Analysis of parseInt() and map() usage in JS
  • Definition and usage analysis of parseInt() function in javascript
  • Javascript function parseInt() has a bug when converting
  • Introduction to the use of the parseInt() method of the global object in javascript
  • JavaScript parseInt() function base conversion attention details

<<:  How to implement Linux deepin to delete redundant kernels

>>:  How to find out uncommitted transaction information in MySQL

Recommend

Detailed explanation of Vue px to rem configuration

Table of contents Method 1 1. Configuration and i...

Learning about UDP in Linux

Table of contents 1. Introduction to UDP and Linu...

MySQL database master-slave configuration tutorial under Windows

The detailed process of configuring the MySQL dat...

Analysis of the difference between emits and attrs in Vue3

Table of contents in conclusion Practice Analysis...

The neglected special effects of META tags (page transition effects)

Using js in web design can achieve many page effec...

Implementation code for installing vsftpd in Ubuntu 18.04

Install vsftpd $ sudo apt-get install vsftpd -y S...

Three principles of efficient navigation design that web designers must know

Designing navigation for a website is like laying...

How to configure tomcat server for eclipse and IDEA

tomcat server configuration When everyone is lear...

JS generates unique ID methods: UUID and NanoID

Table of contents 1. Why NanoID is replacing UUID...

HTML table tag tutorial (19): row tag

The attributes of the <TR> tag are used to ...

Detailed explanation of the application of CSS Sprite

CSS Sprite, also known as CSS Sprite, is an image...

Use of environment variables in Docker and solutions to common problems

Preface Docker can configure environment variable...