例题64位整数乘法

Posted baseai

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了例题64位整数乘法相关的知识,希望对你有一定的参考价值。

题目地址

  • 方法一 (口胡一下就好了啊)

快速幂思想的灵活运用。

\(b\) 用二进制表示 , 设 \(b\) 在二进制下有 \(k\) 位 , \(c_i\) 表示 \(b\) 在二进制下的第 \(i\)

\[b=c_k-1*2^k-1+c_k-2*2^k-2+...+c_0*2^0\]

根据加法原理,\(a*b\) 相当于 \(b\)\(a\) 相加,现在把 \(b\) 用二进制表示,那么就有:

\[a*b=c_k-1*2^k-1*a+c_k-2*2^k-2*a...+c_0*2^0*a\]

根据模运算的规则,边运算边取模。

再打上类似快速幂的板子,就可以分分钟切掉这题了。这里不放代码,因为我没写。

  • 方法二 (玄学方法)

我们知道:

\[a*b \text mod p = a*b-[\fraca*bp]*p\]

注:[ ]暂且看做向下取整

然后书中用了 long double 胡搞一下就过了。反正我是没看懂。

有兴趣的朋友可以写一下。

咱也不知道,咱也不敢问,咱也不想问。

以上是关于例题64位整数乘法的主要内容,如果未能解决你的问题,请参考以下文章

64位整数乘法讲解-And-AcWing-90. 64位整数乘法-方法二

64位整数乘法讲解-And-AcWing-90. 64位整数乘法-《算法竞赛进阶指南》

64位整数乘法讲解-And-AcWing-90. 64位整数乘法-方法二-《算法竞赛进阶指南》

ACwing90 64位整数乘法 大数乘法取模

模板整理~~~~~大整数乘法

[位运算] 64位整数乘法(mod 一个数)