如何避免高精度算法

13 篇文章 0 订阅

则么做有三个条件:

  1. 所有的运算数都不超过long long范围,
  2. 不能有除法
  3. m o d mod mod运算 ( 就是有 n % m ) (\text{就是有}n\%m) (就是有n%m)
    看好了到时候错了 别怪我!!!

就拿一个经典的题来说吧,告诉你 a , b , m a,b,m a,b,m a b   m o d   m a^b\ mod\ m ab mod m都不超过long long 范围
正常的思路:

int a,b,m;
cin >> a >> b >> m;
int s=0;
for(long long i = 1; i <= b; i++)
{
	s*=a;/*!!!*/
}
cout << s%m;

我标记了!!!的地方第二次循环的时候肯定会爆
这时候有一句很有用的话:

只要一个算式中没有除法,并且需要最后取余n,那么你可以在这个算式中塞满取余n,比如(1+1*3)%2可以变成

[1%2+(1%2*3%2)%2]%2

所以上面的代码可以变成

int a,b,m;
cin >> a >> b >> m;
int s=0;
for(long long i = 1; i <= b; i++)
{
	s=a%m*s;
}
cout << s%m;

衷心提示您:请不要用此来做快速幂

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值