大二第一周小总结

取模运算

正常的讲:
(a+b)%mod==(a%mod+b%mod)%mod
除法同理
(ab)%mod==(a%modb%mod)%mod
但是除法是个例外
正常来讲,我们是将除法变成乘法来算的
但是取模运算无法做到
例如:
5/4
b=4
/b即为1/4
但是1/4是分数,无法取模
因此这个思路就是错的
所以还是得求逆元

其实求逆元挺简单的,你只要有快速幂的基础就行了,快速幂的博客我就放着了:

https://blog.csdn.net/qq_19782019/article/details/85621386?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522163056304916780274174507%2522%252C%2522scm%2522%253A%252220140713.130102334…%2522%257D&request_id=163056304916780274174507&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2alltop_positive~default-1-85621386.pc_search_ecpm_flag&utm_term=%E5%BF%AB%E9%80%9F%E5%B9%82&spm=1018.2226.3001.4187
最后只需要对原元素进行mod-2次方就行,快速幂优化,这个逆元就出来了
然后这个逆元就类似于乘法取模运算就行

阶乘预处理

原理类似于求前缀和
既然我后面要多次用到,为了减少运算,why not先把他们求出来呢?
我用多少就求出多少

sum[0]=1;
for(int i=1;i<=5000;i++){
      sum[i]=sum[i-1]*a[i];
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值