」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 有沒有可靠的方法來確定大整數是否為完全平方數?

有沒有可靠的方法來確定大整數是否為完全平方數?

發佈於2024-11-10
瀏覽:340

Is There a Reliable Way to Determine if a Large Integer Is a Perfect Square?

完全平方數和整數:數值探索

確定給定數字是否符合完全平方數最初看起來很簡單。然而,當考慮大整數和複雜的浮點計算時,挑戰變得更加明顯。

基於整數的方法

在沒有迫切需要的情況下為了提高速度,基於整數的方法提供了一種檢查完美平方的可靠方法。這些方法從巴比倫平方根計算演算法中汲取靈感,其根源在於初始近似值的迭代細化最終會導致精確度。

具體而言,以下 Python 函數 is_square() 使用此方法策略:

def is_square(apositiveint):
  x = apositiveint // 2
  seen = set([x])
  while x * x != apositiveint:
    x = (x   (apositiveint // x)) // 2
    if x in seen: return False
    seen.add(x)
  return True

此方法從初始近似值 x 開始,x 定義為輸入 apositiveint 的一半。然後它進入一個迭代過程,其中 x 被修改,直到它收斂於真正的平方根 apositiveint。

為了確保收斂,當前的近似值 x 被儲存在一個集合中,可以看到,以檢查是否有任何先前出現的情況。如果偵測到重複,則表示缺乏收斂,並且函數傳回 False。否則,當 x * x 等於 apositiveint 時,它會傳回 True。

範例驗證

為了說明此方法的功效,請考慮以下範例:

for i in range(110, 130):
   print(i, is_square(i))

此循環迭代從 110 到 129 的整數範圍,檢查每個數字的完全平方狀態。輸出確認了函數的準確性,對於非完美平方列印 false,對於完美平方列印 true。

浮點注意事項

必須注意雖然浮點計算可以提供明顯的解決方案,但它們會帶來捨入誤差的風險,從而導致錯誤的結論。由於整數乘法和求冪是精確運算,因此基於整數的方法可確保精確度,特別是對於大數。

Gmpy 庫

如果速度優先,gmpy庫提供了整數函數的高效實現。特別是,它的 is_square() 方法提供了顯著的效能提升:

import gmpy

gmpy.is_square(x**7)
gmpy.is_square(x**7   1)

這些對非常大的整數執行的操作說明了 gmpy 庫的非凡功能。然而,它的使用可能會引起對計算密集型應用程式的運行時複雜性和記憶體使用的擔憂。

最新教學 更多>
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-18
  • 儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    解決PHP 中的POST 請求故障在提供的程式碼片段中:action=''而不是:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"檢查$_POST數組:表單提交後使用var_dump檢查$_POST 陣列的內容。...
    程式設計 發佈於2024-11-18
  • 如何防止會話劫持:破解共享會話ID之謎?
    如何防止會話劫持:破解共享會話ID之謎?
    防止會話劫持:解決多個客戶端共享單一會話ID 的難題所提出的問題對於維護網路安全至關重要應用程式.該問題圍繞著防止多個客戶端使用相同的會話 ID,從而減少會話劫持嘗試。然而,了解 HTTP 協定的局限性至關重要。 HTTP 的無狀態特性帶來了固有的挑戰。一旦將會話 ID 發佈給用戶,伺服器實際上就不...
    程式設計 發佈於2024-11-18
  • Python 3 的函數註解如何處理集合類型提示?
    Python 3 的函數註解如何處理集合類型提示?
    集合類型提示的函數註釋在Python 3 中,函數註釋是指定類型的常用方法,特別是對於同類集合(例如,列出)。然而,使用者尋求一種將集合類型合併到這些註釋中的方法。 基於文件字串的類型提示最初,Python 開發人員依賴格式化文件字串,例如 reStructuredText 或Sphinx,提供集合...
    程式設計 發佈於2024-11-18
  • 為什麼我的 Chrome 輸入邊框在縮放時消失?
    為什麼我的 Chrome 輸入邊框在縮放時消失?
    Chrome 邊框在縮放時消失問題排查此論壇帖子中提出的問題涉及當用戶放大或縮小時Chrome 中的輸入邊框消失出去。雖然該問題可能並非對所有使用者都普遍存在,但它會影響特定的表單(可在 http://jsfiddle.net/TKb6M/91/ 上找到)。 例如,當縮放到 90% 時,原始表單邊框...
    程式設計 發佈於2024-11-18
  • 如何使用 Properties Maven 插件讀取 Maven 中的外部屬性檔案?
    如何使用 Properties Maven 插件讀取 Maven 中的外部屬性檔案?
    在Maven中讀取外部屬性文件雖然可以使用資源過濾來讀取Maven中的屬性文件,但它可能無法滿足以下要求在pom.xml 中定義特定的屬性檔。要解決這個問題,請考慮利用 Properties Maven 外掛程式。 Properties Maven 外掛程式可讓您讀取 Maven 中的外部屬性檔案。...
    程式設計 發佈於2024-11-18
  • 如何使用Python重命名目錄中的多個檔案?
    如何使用Python重命名目錄中的多個檔案?
    使用Python 重新命名目錄中的多個文件要使用Python 重命名目錄中的多個文件,請考慮使用os .rename(src , dst) 功能,方便重命名或移動檔案和目錄。這是一個範例程式碼片段:import os # Iterate through the files in the direct...
    程式設計 發佈於2024-11-18
  • 如何在 PHP 中將數組值重新索引為數字索引?
    如何在 PHP 中將數組值重新索引為數字索引?
    在PHP 中重新索引數組值考慮以下帶有關聯鍵的數組:$array = [ 'id' => 3, 'user_id' => 1, 'clan_id' => 1, // ... 'skill25xp' => 13373505 ];要將鍵重新...
    程式設計 發佈於2024-11-18
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-18
  • 如何在 WooCommerce 4+ 中將自訂庫存狀態新增至 WooCommerce 產品?
    如何在 WooCommerce 4+ 中將自訂庫存狀態新增至 WooCommerce 產品?
    WooCommerce 4 中WooCommerce 產品的自訂庫存狀態向WooCommerce 4 中的產品添加自訂庫存狀態是一個相對簡單的過程。但需要修改具體功能,才能確保前後端正確顯示狀態。 新增自訂庫存狀態新增自訂庫存狀態,新增將下列程式碼新增至您的functions.php檔案:funct...
    程式設計 發佈於2024-11-18
  • 如何在 Chrome DevTools 中存取 chrome.storage.sync 資料?
    如何在 Chrome DevTools 中存取 chrome.storage.sync 資料?
    在Chrome DevTools 中訪問chrome.storage.sync儘管Chrome DevTools 中提供了本地儲存和會話儲存檢查器,但使用者經常遇到chrome.storage.sync 缺少類似功能的情況。這可以透過替代方法解決。 使用擴充功能進行Chrome 儲存檢查儲存區域檢視...
    程式設計 發佈於2024-11-18
  • Scala Actor 可以取代 Go 的 Goroutine 進行函式庫移植嗎?
    Scala Actor 可以取代 Go 的 Goroutine 進行函式庫移植嗎?
    協程與Actor:Go 和Scala 的比較分析Actor 模型和Goroutines 之間的相似之處讓一些人質疑Scala是否可能是適合移植利用Goroutines 的Go 函式庫的語言。然而,仔細檢查就會發現這兩個概念之間有顯著差異。 協程:通訊順序流程 (CSP) 的基礎Go 中實現的 Gor...
    程式設計 發佈於2024-11-18
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1 和 $array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建...
    程式設計 發佈於2024-11-18
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-18
  • Python 的字串連接優化適用於大字串嗎?
    Python 的字串連接優化適用於大字串嗎?
    如何在Python 中高效地將一個字串附加到另一個字串在Python 中,使用' ' 運算子連接字串是一項常見任務。雖然下面的程式碼很簡單:var1 = "foo" var2 = "bar" var3 = var1 var2它提出了關於效率...
    程式設計 發佈於2024-11-18

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3