恒等式简单常用技巧

目录

引入

1:取模恒等式

2:非取模恒等式


引入

在刷题过程中,我们总会有一个问题:明明感觉代码是对的,但就是wa。然后打开测试数据一看,大部分ac就那么一两个点wa掉。

其实,这就说明代码本身没问题,就是一些细节没有处理好,比如某一个式子超过定义范围等等,这个时候就体现了恒等式的重要性了。

1:取模恒等式

众嗦粥汁,%mod,即为取模。

(1):取模定义恒等:

a%mod==a-a*(a/mod)

(2):单个元素取模恒等:

a%mod==(a%mod+mod)%mod

好处:见恒等式(4),一般单个元素恒等适用于减法。

(3):加法取模恒等:

(a+b)%mod==(a%mod+b%mod)%mod

好处:可以防止a+b的值超过定义范围等。例如a和b都是2^64-1,那么a+b就超过了long long的定义上限范围,相加即为乱码。所以先对a和b取模,可以有效降低数据值,且结果不变。

(4):减法取模恒等:

(a-b)%mod==((a%mod-b%mod)+mod)%mod

好处:可以防止a-b的值超过定义范围等。例如a=-2^64-1,b=2^64-1,那么a-b就超过了long long的定义下限范围。

但是要注意(a-b)!=(a%mod-b%mod)。例如a=5,b=6,mod=3。前者为-1.后者为2。所以要再加一个mod保证结果不变。也就是恒等式(1)。

(5):乘法取模恒等:

(a*b)%mod==((a%mod)*(b%mod))%mod

好处:同样,防止超定义范围等。

(6)乘方取模恒等(令a^b表示a的b次方):

(a^b)%mod==((a%mod)^b)%mod

好处:应用于快速幂,龟速乘,快速乘思想。

2:非取模恒等式

(1):平均恒等:

(a+b)/2==a+(b-a)/2

好处:防止超过定义范围,数组越界等。

但是要注意(a+b)/2!=a/2+b/2。例如a=3,b=5。前者为4,后者为3。

同理:(a-b)/2==a-(a+b)/2

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是孤衾呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值