讀過組合或概率的朋友都知道從種互不相同的東西取種,有種不同的組合,或記作。此式可以寫成以下形式﹕
如果給出一個質數,問除的餘數是多少?
1878年Lucas提出以下定理﹕
當中
和
就是把和寫成進制,然後每一個位的對應系數求相同問題,再取積則成。
把這個問題的轉化有一個好處,就是當非常大的時候,而相對地小,利用Lucas定理運算同樣問題會快很多。剩下的問題就是求除的餘數是多少。把此式展開,
根據模運算,可以計算每分數除的餘數,然後取積除的餘數即可。
問題是,模運算對除的餘數不能直接用分子分母的方法取得。其中一個方法是用擴張輾轉相除法,另一個方法比較巧妙。因為是質數,根據費馬小定理,若與互質,可得以下公式﹕
利用模運算,可得﹕
當中
求除的餘數直接等價於求除的餘數。求可以利上式以時間求出。
由於 ,此問題可以在時間內求出。
延伸﹕因為對於任何系數和,都必然小於。所以當為質數,費馬小定理必然成立。如果當呢?我們可以直接取其餘數,再套入費馬小定理即可。注意當餘數等於表示不存在。
2009年9月28日 星期一
2009年9月8日 星期二
PKU3744 Scout YYF I
本題是POJ月賽八月份題。
題意是某人在整數線上向前走。一開始時他站在第一格。給出向前跳一格的概率為、兩格的概率為、其中。同時給出個不可以停留的格子,問能跳過這個格子的概率是多少。
假設為當前在第格的概率。若果對基本概率有認識的話,不難發現如下關係﹕
由此即可以線性時間求出。然後要跨過的話,。
如此一來解決的問題出現重疊,解法一致,也可以應用於所有。求出答案即是求。
不過在時限內利用線性時間求出答案還是很勉強。不難留意上述公式其實是一個線性遞迴式,由此可以利用矩陣表示其關係﹕
想求出的話則可以利用矩陣乘法,在的時間以如下算式求出﹕
請特別留意當的情況。
還有,死活過不了的朋友,請先為做一遍排序…
題意是某人在整數線上向前走。一開始時他站在第一格。給出向前跳一格的概率為、兩格的概率為、其中。同時給出個不可以停留的格子,問能跳過這個格子的概率是多少。
假設為當前在第格的概率。若果對基本概率有認識的話,不難發現如下關係﹕
由此即可以線性時間求出。然後要跨過的話,。
如此一來解決的問題出現重疊,解法一致,也可以應用於所有。求出答案即是求。
不過在時限內利用線性時間求出答案還是很勉強。不難留意上述公式其實是一個線性遞迴式,由此可以利用矩陣表示其關係﹕
想求出的話則可以利用矩陣乘法,在的時間以如下算式求出﹕
請特別留意當的情況。
還有,死活過不了的朋友,請先為做一遍排序…
訂閱:
文章 (Atom)