Home > Backend Development > Python Tutorial > How to Find Integer Square Roots in Python: Which Method is Best?

How to Find Integer Square Roots in Python: Which Method is Best?

DDD
Release: 2024-10-28 06:03:32
Original
794 people have browsed it

How to Find Integer Square Roots in Python: Which Method is Best?

Calculating Integer Square Roots in Python

In Python, finding an exact integer square root can be a challenge. However, there are several methods available for this task.

One straightforward approach is to use Newton's method, which iteratively refines its estimate of the square root:

<code class="python">def isqrt(n):
    x = n
    y = (x + 1) // 2
    while y < x:
        x = y
        y = (x + n // x) // 2
    return x</code>
Copy after login

This method accurately calculates the largest integer square root, which can then be verified by multiplying it by itself to check if it matches the input number.

An alternative method is to use integer division to iteratively check for perfect squares:

<code class="python">def isqrt2(n):
    i = 1
    while i * i <= n:
        i += 1
    return i - 1</code>
Copy after login

This method has a simpler structure but is generally slower than Newton's method for large integers.

Finally, for Python versions 3.8 and later, the math module provides a built-in isqrt function that calculates the exact integer square root efficiently.

<code class="python">from math import isqrt

x = isqrt(49)  # returns 7</code>
Copy after login

By choosing the appropriate method based on the desired efficiency and Python version, you can accurately find integer square roots in various scenarios.

The above is the detailed content of How to Find Integer Square Roots in Python: Which Method is Best?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template