欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python 實現(xiàn)大整數(shù)乘法算法的示例代碼

 更新時間:2019年09月17日 09:32:36   作者:weixin_43773093  
這篇文章主要介紹了Python 實現(xiàn)大整數(shù)乘法算法的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

我們平時接觸的長乘法,按位相乘,是一種時間復(fù)雜度為 O(n ^ 2) 的算法。今天,我們來介紹一種時間復(fù)雜度為 O (n ^ log 3) 的大整數(shù)乘法(log 表示以 2 為底的對數(shù))。

介紹原理

karatsuba 算法要求乘數(shù)與被乘數(shù)要滿足以下幾個條件,第一,乘數(shù)與被乘數(shù)的位數(shù)相同;第二,乘數(shù)與被乘數(shù)的位數(shù)應(yīng)為  2 次冪,即為 2 ^ 2,  2 ^ 3, 2 ^ 4, 2 ^ n 等數(shù)值。

下面我們先來看幾個簡單的例子,并以此來了解 karatsuba 算法的使用方法。

兩位數(shù)相乘

我們設(shè)被乘數(shù) A = 85,乘數(shù) B = 41。下面來看我們的操作步驟:

將 A, B 一分為二,令 p = A 的前半部分 = 8,q = A 的后半部分 = 5 , r = B 的前半部分 = 4 ,s = B 的后半部分 =  1,n = 2。通過簡單的數(shù)學(xué)運算:

A * B = pq * rs = (p * 10 + q) * (r * 10 + s)  = p * r * 10 ^ 2 + (p * s + q * r ) * 10 + q * s。

令 u = p * r,v =(p - q) * (s - r),w = q * s。所以 A * B =  u * 10 ^ 2 + (u + v + w) * 10 + w。

換成數(shù)值求解的過程如下:

A * B = 85 * 41 = (8 * 10 + 5) * ( 4 * 10 + 1) = 8 * 4 * 10 * 10 + (8 * 1 + 5 * 4) * 10 + 5 * 1。

其中 u = 8 * 4 = 32,v = (8 - 5) (1 - 4) = -9,w = 5 * 1 = 5。

所以,A * B = 32 * 100 + (32 - 9 + 5) * 10 + 5 = 3485。與長乘法所得結(jié)果一致。

四位數(shù)相乘

我們設(shè)被乘數(shù) A = 8537,乘數(shù) B = 4123。下面來看我們的操作步驟:

將 A, B 一分為二,令 p = A 的前半部分 = 85,q = A 的后半部分 = 37 , r = B 的前半部分 = 41 ,s = B 的后半部分 =  23,n = 4。

==> 其中,u = 85 * 41, v = (85 - 37) * (23 - 41), w = 37 * 23。

==> A * B = 8537 * 4123 = u * 10 ^ 4 + (u + v + w) * 10 ^ 2 + w =  3485_0000 +34_7200 + 851 = 35198051。

在我們計算 u, v,  w 的過程中又會涉及兩位數(shù)的乘法,我們繼續(xù)使用 Karatsuba 算法得出兩位數(shù)相乘的結(jié)果。

N 位數(shù)相乘

我們令 n 為 乘數(shù)與被乘數(shù)的位數(shù),令 p = A 的前半部分,q = A 的后半部分, r = B 的前半部分 ,s = B 的后半部分。

==> 其中, u = p * r,v = (p - q) * (s - r),w = q * s。

所以 A * B =  u * 10 ^ n + (u + v + w) * 10 ^ (n / 2) + w。

而 u, v, w 則是兩個 n / 2 位的乘法運算。我們繼續(xù)調(diào)用 Karatsuba 算法計算 u, v, w 的數(shù)值。接著,我們在計算 n / 2 乘法的過程中又會遇到 n / 4 位的乘法運算……以此類推,直到我們遇到兩個個位數(shù)的乘法,我們就直接返回這兩個個位數(shù)乘法的結(jié)果。層層返回,最終得到 N 位數(shù)的乘法結(jié)果。

時間復(fù)雜度

我們平常使用的長乘法,是 O (n ^ 2) 的時間復(fù)雜度。比如兩個 N 位數(shù)相乘,我們需要將每一位按規(guī)則相乘,所以需要計算  N * N 次乘法。而使用  Karatsuba 算法每層需要計算三次乘法,兩次加法,以及若干次加法,每使用一次 karatsuba 算法,乘法規(guī)模就下降一半。

所以,對于兩個 n =  2 ^ K 位數(shù)乘法運算,我們需要計算 3 ^ k 次乘法運算。而 K = log n(底數(shù)為 2), 3 ^ K = 3 ^ log n = 2  ^ (log 3 * log n) = 2 ^ (log n * log 3) = n ^ log 3 (底數(shù)為 2)。

代碼實現(xiàn)

from math import log2, ceil
 
def pad(string: str, real_len: int, max_len: int) -> str:
  pad_len: int = max_len - real_len
  return f"{'0' * pad_len}{string}"
 
 
def kara(n1: int, n2: int) -> int:
  if n1 < 10 or n2 < 10:
    return n1 * n2
  n1_str: str = str(n1)
  n2_str: str = str(n2)
  n1_len: int = len(n1_str)
  n2_len: int = len(n2_str)
  real_len: int = max(n1_len, n2_len)
  max_len: int = 2 ** ceil(log2(real_len))
  mid_len: int = max_len >> 1
  n1_pad: str = pad(n1_str, n1_len, max_len)
  n2_pad: str = pad(n2_str, n2_len, max_len)
  p: int = int(n1_pad[:mid_len])
  q: int = int(n1_pad[mid_len:])
  r: int = int(n2_pad[:mid_len])
  s: int = int(n2_pad[mid_len:])
  u: int = kara(p, r)
  v: int = kara(q-p, r-s)
  w: int = kara(q, s)
  return u * 10 ** max_len + (u+v+w) * 10 ** mid_len + w

輸出結(jié)果:

==> kara(123456, 9734) == 123456 * 9734

==> kara(1234233456756, 32459734) == 1234233456756 * 32459734

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python數(shù)據(jù)可視化 pyecharts實現(xiàn)各種統(tǒng)計圖表過程詳解

    Python數(shù)據(jù)可視化 pyecharts實現(xiàn)各種統(tǒng)計圖表過程詳解

    這篇文章主要介紹了Python數(shù)據(jù)可視化 pyecharts實現(xiàn)各種統(tǒng)計圖表過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-08-08
  • 基于Python實現(xiàn)天天酷跑功能

    基于Python實現(xiàn)天天酷跑功能

    這篇文章主要介紹了基于Python實現(xiàn)天天酷跑功能,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • Python天氣語音播報小助手

    Python天氣語音播報小助手

    馬上就要迎來國慶小長假了,激不激動,興不興奮!那今年國慶:天氣怎么樣?能不能出門逛街?能不能出去旅游?旅游出門就要挑個好的天氣!下雨天哪兒哪兒都不舒服。今天小編帶大家寫一款Python天氣語音播報小助手
    2021-09-09
  • 解讀等值線圖的Python繪制方法

    解讀等值線圖的Python繪制方法

    這篇文章主要介紹了解讀等值線圖的Python繪制方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • python人工智能tensorflow常見損失函數(shù)LOSS匯總

    python人工智能tensorflow常見損失函數(shù)LOSS匯總

    這篇文章主要為大家介紹了python人工智能tensorflowf常見損失函數(shù)LOSS匯總,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • python 獲取list特定元素下標(biāo)的實例講解

    python 獲取list特定元素下標(biāo)的實例講解

    下面小編就為大家分享一篇python 獲取list特定元素下標(biāo)的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • python區(qū)塊鏈實現(xiàn)簡版網(wǎng)絡(luò)

    python區(qū)塊鏈實現(xiàn)簡版網(wǎng)絡(luò)

    這篇文章主要為大家介紹了python區(qū)塊鏈實現(xiàn)簡版網(wǎng)絡(luò)的詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • Python之requests的使用(二)

    Python之requests的使用(二)

    上一篇我們說了requests的簡單用法,知道了如何發(fā)送請求,今天我們更深層次的來學(xué)習(xí)requests。我們看看高級一點的操作,比如講文件上傳,cookies設(shè)置,代理設(shè)置之類的。感興趣的同學(xué)可以參考閱讀
    2023-04-04
  • python Pandas庫基礎(chǔ)分析之時間序列的處理詳解

    python Pandas庫基礎(chǔ)分析之時間序列的處理詳解

    這篇文章主要介紹了python Pandas庫基礎(chǔ)分析之時間序列的處理詳解,Pandas作為Python環(huán)境下的數(shù)據(jù)分析庫,更是提供了強(qiáng)大的日期數(shù)據(jù)處理的功能,是處理時間序列的利器,需要的朋友可以參考下
    2019-07-07
  • Python 點擊指定位置驗證碼破解的實現(xiàn)代碼

    Python 點擊指定位置驗證碼破解的實現(xiàn)代碼

    這篇文章主要介紹了Python 點擊指定位置驗證碼破解的實現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09

最新評論