編輯變長#秒[概念]
的有效倍增所以看起來我「低估」不同長度的數字是什麼意思。我甚至沒有想到操作數爲100位數的情況。在那種情況下,我提出的算法肯定是不高效的。我可能需要一個實現複雜性的實現取決於每個操作數中的數字,而不是其數值,對吧?
如下的建議,我會考慮的karatsuba算法...
寫一個算法,在兩個任意長度的數字需要(如串提供)的僞代碼,並計算產品這些數字。使用一個有效的程序來乘以大量的任意長度。分析算法的效率。
我決定採取(半)簡單的方法,並使用俄羅斯農民算法。它的工作原理是這樣的:
a * b = a/2 * 2b if a is even
a * b = (a-1)/2 * 2b + a if a is odd
我的僞代碼:
rpa(x, y){
if x is 1
return y
if x is even
return rpa(x/2, 2y)
if x is odd
return rpa((x-1)/2, 2y) + y
}
我有3個問題:
- 這是有效的任意長度的數字?我用C實現它,嘗試了不同的長度數字。在所有情況下,運行時間幾乎是瞬間的,因此很難根據經驗來說明...
- 我可以應用主定理來理解複雜性嗎?
- 在遞歸一個=#子問題= 1(最大1遞歸跨越所有狀態呼叫)
- N/B =大小每個子問題= N/1的 - > B = 1(問題不改變大小.. ?)
- f(n^d)=在遞歸調用外完成的工作= 1 - > d = 0(當a是奇數時的加法)
- a = 1,b^d = 1,a = b^d - >複雜性在n^d * log(n)= log(n)
- 這在邏輯上合理,因爲我們在每一步都將問題減半,對嗎?
- 我的教授通過提供任意長度的「字符串」可能意味着什麼。爲什麼這樣做?
提前
非常感謝
他想給你的數字作爲字符串,因爲你使用的任何語言的內置數據類型都被限制在某個最大大小。如果他希望你通過23459876235987623598723645982346598234659823465982346529834乘以198347523458623586235875932485,那麼字符串就可以很好地表示這些數字。我猜你現在的算法不能處理那些輸入...... – 2012-03-24 23:21:24
你的教授意味着這些數字可能太大而不適合機器字,所以他們必須被提供爲任意長度的ASCII字符串(據推測)以10爲底。例如,「123456789876543211112222333344445」。所以你的算法恐怕是不完整的。但是你也可以在字符串上使用俄羅斯農民算法 - 你只需要做更多的工作: -/ – TonyK 2012-03-24 23:22:46
哦,我明白了。有道理 - 謝謝你清理那個。 – 2012-03-24 23:23:32