概要 2^n-1 型の数はメルセンヌ数と呼ばれ、更に素数である場合にメルセンヌ素数といいます。本記事では、メルセンヌ数に対する高速な素数判定法であるリュカ・レーマーテストを、Rustの任意精度演算用クレート rug を利用して実装します。 実行環境 CPU: Intel Core i7 1.8GHz メモリ: 16GB OS(ホスト): Windows 10 Home 21H1 WSL2: Ubuntu 20.04.3 rustc: Ver. 1.55.0 cargo: Ver. 1.55.0 符号付き整数型の範囲について Rustには組み込みの整数型として 8,\,16,\,32,\,64,\,128 ビット整数[1]がそれぞれ符号付き・符号なしで備わっています[2]。そのうち符号付き整数は、他の多くの言語と同様、2の補数によって負の数が表現されます。したがって、ビット数 n = 8,
![128ビット符号付き整数の最大値は素数 - Rustで任意精度整数演算](https://cdn-ak-scissors.b.st-hatena.com/image/square/8f7b23ec040480d457e7131e7397cd3f24156aaf/height=288;version=1;width=512/https%3A%2F%2Ffanyv88.com%3A443%2Fhttps%2Fres.cloudinary.com%2Fzenn%2Fimage%2Fupload%2Fs--VCOIwLzm--%2Fc_fit%252Cg_north_west%252Cl_text%3Anotosansjp-medium.otf_55%3A128%2525E3%252583%252593%2525E3%252583%252583%2525E3%252583%252588%2525E7%2525AC%2525A6%2525E5%25258F%2525B7%2525E4%2525BB%252598%2525E3%252581%25258D%2525E6%252595%2525B4%2525E6%252595%2525B0%2525E3%252581%2525AE%2525E6%25259C%252580%2525E5%2525A4%2525A7%2525E5%252580%2525A4%2525E3%252581%2525AF%2525E7%2525B4%2525A0%2525E6%252595%2525B0%252520-%252520Rust%2525E3%252581%2525A7%2525E4%2525BB%2525BB%2525E6%252584%25258F%2525E7%2525B2%2525BE%2525E5%2525BA%2525A6%2525E6%252595%2525B4%2525E6%252595%2525B0%2525E6%2525BC%252594%2525E7%2525AE%252597%252Cw_1010%252Cx_90%252Cy_100%2Fg_south_west%252Cl_text%3Anotosansjp-medium.otf_37%3Aroiban%252Cx_203%252Cy_121%2Fg_south_west%252Ch_90%252Cl_fetch%3AaHR0cHM6Ly9zdG9yYWdlLmdvb2dsZWFwaXMuY29tL3plbm4tdXNlci11cGxvYWQvYXZhdGFyL2Y3NmUxNzBmNjIuanBlZw%3D%3D%252Cr_max%252Cw_90%252Cx_87%252Cy_95%2Fv1627283836%2Fdefault%2Fog-base-w1200-v2.png)