取模运算

在散列表这类的应用中,除留余数法是比较常见的。在使用除留余数法时取模运算是必不可少的,接下来介绍下取模运算:
法则:
1.(a+b)%p=(a%p+b%p)%p
2.(a-b)%p=(a%p-b%p)%p
3.(a*b)%p=((a%p)*(b%p))%p
4.(a^b)%p=((a%p)^b)%p
5.((a+b)%p+c)%p=(a+(b+c)%p)%p
应用场景:
1.判别奇偶数
2.判别素数——用比该数的平方根小的正整数去除这个数
3.求最大公约数——欧几里得辗转相除(gcd(a,b)=gcd(b,(a)mod(b)))
4.求幂运算——例如想知道一个较大的数—a的b次幂的最后一位是多少
5.密码学应用
其中4的应用较为有意思,可以将时间复杂度限定在O(b^1/2)b表示指数,示例demo如下:

//x为底数,n为指数,p为模数
//思路:n为偶数时x^n=(x*x)^[n/2] 
//      n为奇数时 x^n=x*(x*x)^[n/2]
#include <stdio.h>
unsigned int PowerMod(unsigned int x,unsigned int n,unsigned int p);

int main()
{
    printf("result:%d",PowerMod(3333,77777,10));
    return 0;
} 
unsigned int PowerMod(unsigned int x,unsigned int n,unsigned int p)
{

   if(n==0)
   {
    return 1;
   }
   unsigned int temp1=(x*x)%p;
   unsigned int temp=PowerMod(temp1,n/2,p);//递归的原因是由于n为奇数导致。 
   if((n&1)!=0)//n为奇数 ,将式子展开后,奇数时多出这一步 
   temp=(temp*(x%p))%p;

   return temp;
}

按照这种方式可以极大地降低时间复杂度(=^ ^=)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值