(9173501 * 9173502 * 9173504) % 9173503
C# で計算する必要があります。結果 = 2 ですが、C# では計算できません。何かアイデアがあれば、私を助けてください。
4 に答える
47
大きな整数を使用する必要はありません。
次の式を使用します。
(x * y) % k = ((x % k) * (y % k)) % k
このようにして、それぞれが になる 2 つの数値の積にモジュロを適用できる< 9173503
ため、この積は に収まりlong
ます。
注:同じことが足し算にも当てはまります:
(x + y) % k = ((x % k) + (y % k)) % k
そして、わずかな変更を加えた減算:
(x - y) % k = ((((x % k + k) % k) - ((y % k + k) % k)) % k + k) % k
ただし、除算には当てはまりません。
(4 / 2) % 3 = 2
4 mod 3 = 1
2 mod 3 = 2
1 / 2 != 2
于 2013-09-26T18:32:46.827 に答える
9
計算を開始する前に、数値を BigInteger に変換します。
Console.WriteLine((new BigInteger(9173501)*9173502*9173504)%9173503);
// Output: 2
于 2013-09-26T18:32:08.183 に答える
5
なしで直接計算することはできませんBigInteger
が、数学的には次と同等です。
((long)9173501 % 9173503) * (9173502 % 9173503) * (9173504 % 9173503) % 9173503
于 2013-09-26T18:33:23.527 に答える
1
これは数学の問題であり、プログラミングの問題ではありません。
ご覧のとおり、数値は互いに非常に近いため、置き換えると次のn = 9173503
ようになります(n-2)(n-1)(n+1) % n
。
括弧を開くと、次の多項式が得られます。n^3 - 2*n^2 - n + 2
残りは次のようn
になります。
- n > 2 ごとに 2
- n = 1、2 の場合は 0
これは、 だけ(9173501 * 9173502 * 9173504) % 9173503 = 2
でなく も13^127^61 * (13^127^61 + 1) * (13^127^61 + 3) % (13^127^61 + 2)
意味し2
ます。これは、C# や他のプログラミング言語では計算できない可能性が最も高いです。
于 2014-01-13T20:55:56.263 に答える