亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Python 實(shí)現(xiàn)大整數(shù)乘法算法

系統(tǒng) 2396 0

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

介紹原理

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

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

兩位數(shù)相乘

我們?cè)O(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é)運(yùn)算:

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ù)相乘

我們?cè)O(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。

在我們計(jì)算 u, v, ?w 的過程中又會(huì)涉及兩位數(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 則是兩個(gè) n / 2 位的乘法運(yùn)算。 我們繼續(xù)調(diào)用 Karatsuba 算法計(jì)算 u, v, w 的數(shù)值。 接著,我們?cè)谟?jì)算 n / 2 乘法的過程中又會(huì)遇到 n / 4 位的乘法運(yùn)算……以此類推,直到我們遇到兩個(gè)個(gè)位數(shù)的乘法,我們就直接返回這兩個(gè)個(gè)位數(shù)乘法的結(jié)果。 層層返回,最終得到 N 位數(shù)的乘法結(jié)果。

時(shí)間復(fù)雜度

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

所以,對(duì)于兩個(gè) n = ?2 ^ K 位數(shù)乘法運(yùn)算,我們需要計(jì)算 3 ^ k 次乘法運(yùn)算。 而 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)。

代碼實(shí)現(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


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 日韩精品欧美高清区 | 日韩一区二区在线视频 | 亚洲欧美天堂网 | 免费尤物视频 | 91国内视频| 日本一本二本免费播放视频 | 毛片69| 一本本久综合久久爱 | 久久亚洲欧美 | 欧洲成人在线视频 | 日韩亚洲一区中文字幕在线 | 欧美日韩在线免费观看 | 91亚洲国产成人久久精品网站 | 九九热最新 | 成人淫片免费视频95视频 | 美国毛片免费观看 | 欧美成人免费网在线观看 | 久久综合精品不卡一区二区 | a级亚洲片精品久久久久久久 | 天天操天天干天天透 | se999se男人最爱 | 青青草免费视频在线播放 | 亚洲一二区视频 | 奇米精品 | 欧美曰韩一区二区三区 | 国产成人亚洲欧美三区综合 | 亚洲欧美色综合自拍 | 激情福利网 | 成人日韩欧美 | 一区二区三区四区免费视频 | 亚洲成人小视频 | 国产精品99久久99久久久看片 | 伊人色婷婷 | 国产色视频一区 | 香蕉久久一区二区三区 | 日韩精品久久不卡中文字幕 | 久久国产乱子伦精品免费一 | 国产区91| 日韩精品一区二区三区中文精品 | 国内夫妇精品对白在线播放 | 免费香蕉一区二区在线观看 |