私はちょうど大学関連の Diffie Hellmann の演習を行っており、そのために ruby を使用しようとしました。悲しいことに、Ruby は大きな指数を処理できないようです。
警告: a**b では、b が大きすぎる可能性があります
NaN
[...]
それを回避する方法はありますか?(例えば、特別な数学のクラスか、それに沿った何か?)
ps問題のコードは次のとおりです。
generator = 7789
prime = 1017473
alice_secret = 415492
bob_secret = 725193
puts from_alice_to_bob = (generator**alice_secret) % prime
puts from_bob_to_alice = (generator**bob_secret) % prime
puts bobs_key_calculation = (from_alice_to_bob**bob_secret) % prime
puts alices_key_calculation = (from_bob_to_alice**alice_secret) % prime