So, If i would like to calculate the value of 6^8 mod 5 using the pow function, what should I put in a line??
In the assumption that You don't need to import it first
I know that pow is used like pow (x, y) = pow (6, 8) = 6^8 and
My guess is
mod.pow(6,8)
Thank you!
It's simple:
pow
takes an optional 3rd argument for the modulus.From the docs:
So you want:
Not only is
pow(x, y, z)
faster & more efficient than(x ** y) % z
it can easily handle large values ofy
without using arbitrary precision arithmetic, assumingz
is a simple machine integer.check the docs of
pow
:does what you want.
do not use
a ** b % n
! while this will give the correct result it will be by orders of magnitude slower if you do calculations for bigger numbers.pow
will do the modulo operation in every step while**
will first do the exponentiation in the integers (which may result in a huge number) and take the modulus only at the end.now if you are interested in numbers that are bigger than 32 bit you may want to have a look at gmpy2 for even more speed.
You can use '%' character to get the modulo value. For example
print(pow(6,8) % 5)
orprint(6**8 % 5)
.