How can I find modular multiplicative inverses of a range in linear time?
# | User | Rating |
---|---|---|
1 | jiangly | 4039 |
2 | tourist | 3841 |
3 | jqdai0815 | 3682 |
4 | ksun48 | 3590 |
5 | ecnerwala | 3542 |
6 | Benq | 3535 |
7 | orzdevinwang | 3526 |
8 | gamegame | 3477 |
9 | heuristica | 3357 |
10 | Radewoosh | 3355 |
# | User | Contrib. |
---|---|---|
1 | cry | 168 |
2 | -is-this-fft- | 165 |
3 | atcoder_official | 160 |
3 | Um_nik | 160 |
5 | djm03178 | 157 |
6 | Dominater069 | 156 |
7 | adamant | 153 |
8 | luogu_official | 152 |
9 | awoo | 151 |
10 | TheScrasse | 147 |
How can I find modular multiplicative inverses of a range in linear time?
Name |
---|
Do you want to find a multiplicative inverse for all numbers from 1 to N — 1?
It can be easily done for a prime N, the idea should be obvious if you'll read about primitive roots modulo N.
For non-prime N the idea should also be similar.
I read about primitive roots that -
If the prime number is p, a primitive root g is a number, that when n goes from [1...p - 1], then gn mod p goes through all the numbers [1...p - 1] in some order.
How do I utilize this further? Sorry but I am unable to really understand how to form a relation between modular inverse and primitive root.
If you thought harder, you'd come up with an idea :).
Due to Fermat's Little Theorem: .
if the number with respect to which you are finding the modular inverse (i.e. the 'M' in A%M is prime)you can use the Fermat's little theorem according to which the modular inverse of a number with respect to a prime number (say A and P respectively) is pow(A,P-2)
so in one for loop you may find the modular multiplicative inverses of the numbers in the range but the complexity is O(nlogp) as the power function takes log(p) time
http://e-maxx.ru/algo/reverse_element#4 (it's in russian but you can see the code)
Can you please explain the last step before QED in the proof provided?
What have they done after taking mod m on both sides?
They've multiplied both sides of the equality by
r[i] * r[m mod i]
.