zoukankan      html  css  js  c++  java
  • 快速幂详解【模板】

    快速幂

    洛谷链接

    AcWing链接


    快速幂的思想

    当我们求37

    朴素算法就是Pow,或者连乘7次,这个要进行7次运算

    但我们可以用快速幂的思想

    31=3
    32=9
    33=81

    然后再将三次的值相加,就可以求出37
    这个思想还可以用于这道题 64位整数乘法

    这个思想非常高效,可以将原来O(n)的算法改成O(log2n)


    快速幂的模板

    int qmi(int m, int k, int p)
    {
        int res = 1 % p, t = m;
        while (k)
        {
            if (k&1) res = res * t % p;
            t = t * t % p;
            k >>= 1;
        }
        return res;
    }
    

    时间复杂度为(log2n)


    Ac Code 1(AcWing)

    #include <cstdio>
    
    using namespace std;
    int a,b,p;
    
    
    int main()
    {
        scanf("%d%d%d",&a,&b,&p);
        int res=1 % p;
        //%p是因为要防止b=0即0次方,一旦b=0的话,就不会循环,导致输出的时候没有%p
        while(b)
        {
            if(b&1) res= res *1ll *a % p;
            //可能int会存不下,所以*1ll化为long long
            a = a * 1ll * a % p;
            b >>= 1;  //去掉个位
        }
        printf("%d", res);
        
        return 0;
    }
    

    Ac Code 2 (洛谷)

    #include <cstdio>
    
    using namespace std;
    int a,b,p;
    
    
    int main()
    {
        scanf("%d%d%d",&a,&b,&p);
        int res=1 % p;
        int a1=a,b1=b; 
        //%p是因为要防止b=0即0次方,一旦b=0的话,就不会循环,导致输出的时候没有%p
        while(b)
        {
            if(b&1) res= res *1ll *a % p;
            //可能int会存不下,所以*1ll化为long long
            a = a * 1ll * a % p;
            b >>= 1;  //去掉个位
        }
        printf("%d^%d mod %d=%d",a1,b1,p, res);
        
        return 0;
    }
    
  • 相关阅读:
    python知识点整理一
    Selenium之自动化常遇问题
    git学习
    哈,又是总结内容
    2.3返回IP地址(requests模块安装,get请求发送,loads 解析json到字典)
    2.2返回状态码的分类描述
    2.1JSON数据格式
    1.6file文件
    福利:字符串与字符编码
    1.5list中sort && sorted
  • 原文地址:https://www.cnblogs.com/BorisDimitri/p/13546609.html
Copyright © 2011-2022 走看看